当前位置: 首页 > article >正文

redis的三种客户端

在 Redis 中,常用的 Java 客户端有三种:JedisLettuceRedisson。它们各有特点,适用于不同的场景。以下是它们的详细介绍,以及如何在 Spring Boot 中集成 Redis。


一、Redis 三种常用客户端详解

1.1 Jedis

Jedis 是 Redis 官方推荐的 Java 客户端,采用同步、阻塞的 I/O 模型。它简单易用,提供了丰富的 Redis API 支持,并支持连接池。

  • 特点

    • 同步阻塞:所有 Redis 操作都是同步执行的,当前线程会等待操作完成。
    • 多线程支持:Jedis 需要为每个线程创建独立的 Jedis 实例(连接),可以使用连接池来管理这些连接。
    • 高性能:Jedis 性能优异,但需要注意连接池的配置,以免连接耗尽。
  • 适用场景:适合简单的同步操作,适用于较小的并发量下进行同步阻塞的 Redis 操作。

1.2 Lettuce

Lettuce 是一个基于 Netty 的 Redis 客户端,支持异步和同步操作,连接默认是线程安全的。Lettuce 在 Spring Boot 的 Redis 自动配置中默认集成。

  • 特点

    • 支持异步、同步和响应式操作:Lettuce 支持 Future 异步调用,还可以与 Reactor 框架集成实现响应式操作。
    • 线程安全:默认单实例即可支持多线程访问,无需连接池。
    • 基于 Netty:Lettuce 具有较好的性能和资源利用率,适合高并发和低延迟场景。
  • 适用场景:适合高并发场景下的异步处理,尤其在 Spring Boot 中作为默认选择。

1.3 Redisson

Redisson 是一个功能丰富的 Redis 客户端库,主要用于构建分布式系统,它提供了丰富的分布式工具,例如分布式锁、分布式集合、分布式队列等。

  • 特点

    • 支持分布式对象和服务:Redisson 提供了分布式锁、队列、集合、信号量等分布式工具,简化了在分布式系统中使用 Redis 的实现。
    • 简单易用的 API:Redisson 提供了许多基于 Java 原生集合的接口。
    • 可扩展性强:支持 Redis Cluster 和 Redis Sentinel,实现高可用和高扩展性。
  • 适用场景:适合构建分布式系统,使用分布式锁、分布式缓存和分布式集合等工具的场景。


二、Spring Boot 集成 Redis 客户端

Spring Boot 集成 Redis 非常简单,以下是如何集成三种不同 Redis 客户端的方法。

2.1 使用 Jedis 客户端集成
  1. 引入依赖

    pom.xml 中引入 spring-boot-starter-data-redis 和 Jedis 依赖:

    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-data-redis</artifactId>
    </dependency>
    <dependency>
        <groupId>redis.clients</groupId>
        <artifactId>jedis</artifactId>
        <version>4.0.1</version> <!-- 版本可能会更新,请选择合适的版本 -->
    </dependency>
    
  2. 配置 Jedis 连接池

    application.yml 中配置 Jedis 连接池:

    spring:
      redis:
        host: localhost
        port: 6379
        jedis:
          pool:
            max-active: 10
            max-idle: 5
            min-idle: 1
    
  3. 使用 RedisTemplate

    Spring Boot 会自动配置 RedisTemplate,直接注入使用即可:

    @Service
    public class RedisService {
    
        @Autowired
        private RedisTemplate<String, Object> redisTemplate;
    
        public void setValue(String key, String value) {
            redisTemplate.opsForValue().set(key, value);
        }
    
        public String getValue(String key) {
            return (String) redisTemplate.opsForValue().get(key);
        }
    }
    
2.2 使用 Lettuce 客户端集成(Spring Boot 默认配置)
  1. 引入依赖

    pom.xml 中只需添加 spring-boot-starter-data-redis 依赖,因为它默认使用 Lettuce 作为 Redis 客户端:

    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-data-redis</artifactId>
    </dependency>
    
  2. 配置 Lettuce

    application.yml 中可以简单配置 Redis 信息,Spring Boot 会默认使用 Lettuce:

    spring:
      redis:
        host: localhost
        port: 6379
        lettuce:
          pool:
            max-active: 10
            max-idle: 5
            min-idle: 1
    
  3. 使用 RedisTemplate

    使用 RedisTemplate 同样简单:

    @Service
    public class RedisService {
    
        @Autowired
        private RedisTemplate<String, Object> redisTemplate;
    
        public void setValue(String key, String value) {
            redisTemplate.opsForValue().set(key, value);
        }
    
        public String getValue(String key) {
            return (String) redisTemplate.opsForValue().get(key);
        }
    }
    
2.3 使用 Redisson 客户端集成
  1. 引入依赖

    pom.xml 中引入 Redisson 依赖:

    <dependency>
        <groupId>org.redisson</groupId>
        <artifactId>redisson-spring-boot-starter</artifactId>
        <version>3.17.5</version> <!-- 版本可能会更新,请选择合适的版本 -->
    </dependency>
    
  2. 配置 Redisson

    application.yml 中添加 Redisson 配置:

    spring:
      redis:
        host: localhost
        port: 6379
    
  3. 定义 Redisson 配置类

    使用 RedissonClient 作为 Bean 注册:

    import org.redisson.api.RedissonClient;
    import org.redisson.config.Config;
    import org.springframework.context.annotation.Bean;
    import org.springframework.context.annotation.Configuration;
    
    @Configuration
    public class RedissonConfig {
    
        @Bean
        public RedissonClient redissonClient() {
            Config config = new Config();
            config.useSingleServer()
                  .setAddress("redis://localhost:6379")
                  .setConnectionPoolSize(10);
            return Redisson.create(config);
        }
    }
    
  4. 使用分布式锁示例

    Redisson 提供了丰富的分布式数据结构,例如分布式锁 RLock

    import org.redisson.api.RLock;
    import org.redisson.api.RedissonClient;
    import org.springframework.beans.factory.annotation.Autowired;
    import org.springframework.stereotype.Service;
    
    import java.util.concurrent.TimeUnit;
    
    @Service
    public class RedissonService {
    
        @Autowired
        private RedissonClient redissonClient;
    
        public void doSomethingWithLock() {
            RLock lock = redissonClient.getLock("my-lock");
            try {
                // 尝试加锁,最多等待 5 秒,锁定 10 秒自动释放
                if (lock.tryLock(5, 10, TimeUnit.SECONDS)) {
                    try {
                        // 加锁成功,执行任务
                        System.out.println("Lock acquired, executing task...");
                    } finally {
                        lock.unlock();
                    }
                }
            } catch (InterruptedException e) {
                Thread.currentThread().interrupt();
            }
        }
    }
    

三、总结

  • Jedis:简单易用,适合同步操作,需注意多线程问题。
  • Lettuce:Spring Boot 默认使用的客户端,支持异步和同步,线程安全。
  • Redisson:提供丰富的分布式工具,适合需要分布式锁、分布式集合等高级功能的场景。

在 Spring Boot 项目中,可以根据业务需求选择合适的客户端。例如,高并发或异步场景中更适合 Lettuce,而在分布式环境中 Redisson 能提供更多高级功能。


http://www.kler.cn/a/371474.html

相关文章:

  • 计算机组成原理(九):乘法器
  • 【华为OD-E卷 - 篮球比赛 100分(python、java、c++、js、c)】
  • 数据结构(Java版)第七期:LinkedList与链表(二)
  • LabVIEW软件Bug的定义与修改
  • YARN WebUI 服务
  • Windows11环境下设置MySQL8字符集utf8mb4_unicode_ci
  • SpringMVC学习(2)
  • Mac开发环境配置- Shell/Homebrew/ruby
  • ele-table表格列表内,双击编辑部分信息(el-table组件同理)
  • C# OpenCvSharp DNN UNet 推理
  • 华为手机系统应用瘦身
  • 了解桌面机床用于学校教学培训应用-桌面级CNC机床
  • Debug日程工作经验总结日程常用
  • 五指cms安装
  • ubuntu20.04系统安装
  • 使用Python和OpenCV实现火焰检测
  • c++ assert
  • [机器学习]集成学习
  • Docker架构
  • [论文阅读]SimCSE: Simple Contrastive Learning of Sentence Embeddings
  • Topaz Video AI for Mac 视频无损放大软件安装教程【保姆级,操作简单轻松上手】
  • 《ToDesk 云电脑、易腾云、青椒云移动端体验实测:让手机秒变超级电脑》
  • 鸿蒙NEXT应用上架与分发
  • 沧穹科技室内音频“北斗”定位技术亮相第三届北斗规模应用国际峰会
  • 面试题整理1
  • Flume采集Kafka数据到Hive