Java中Redis连接客户端的使用:jedis、spring-data-redis与spring-boot-starter-data-redis的关系与区别

弘烨烁
2023-12-01

项目中需要用到redis,主要用来作为缓存,redis的客户端有两种实现方式:
一、是可以直接调用jedis来实现。
二、是可以使用spring data redis,通过spring的封装来调用。
三、是使用spring-boot-start-redis来调用(spring-data-redis与spring-boot-starter-data-redis是啥关系啊,这么多Sping怎么搞了两个?脑子不好使啊)。

1、Jedis

Jedis Client是Redis官网推荐的一个面向java客户端,库文件实现了对redis各类API进行封装调用。redis通信协议是Redis客户端与Redis Server之间交流的语言,它规定了请求和返回值的格式。redis-cli与server端使用一种专门为redis设计的协议RESP(Redis Serialization Protocol)交互,Resp本身没有指定TCP,但redis上下文只使用TCP连接。

2、Spring Data Redis

首先Spring Data Redis 是Spring 框架提供的用于操作Redis的客户端,优点有:

1.对具体redis客户端做了封装,客户端可在jedis,jredis,rjc等Java客户端中做出选择和切换

2.用template对调用做了封装,省去了建立连接,释放连接等繁琐代码。

3.对对象的序列化也可自由选择工具。

4.提供对spring cache的支持,可用注解实现Cache —— 但是无法设定缓存失效时间。

3、spring-data-redis与spring-boot-starter-data-redis啥关系?

Spring-boot-starter-data-Redis的pom.xml。可以清晰的看到,它里面包含了Spring-data-redis,所以两者的关系是包含与被包含的关系,或者说前者更好的封装了后者。

4、Jedis和Lettuce的区别

jedis和Lettuce都是Redis的客户端,它们都可以连接Redis服务器,但是在SpringBoot2.0之后默认都是使用的Lettuce这个客户端连接Redis服务器。因为当使用Jedis客户端连接Redis服务器的时候,每个线程都要拿自己创建的Jedis实例去连接Redis客户端,当有很多个线程的时候,不仅开销大需要反复的创建关闭一个Jedis连接,而且也是线程不安全的,一个线程通过Jedis实例更改Redis服务器中的数据之后会影响另一个线程;

但是如果使用Lettuce这个客户端连接Redis服务器的时候,就不会出现上面的情况,Lettuce底层使用的是Netty,当有多个线程都需要连接Redis服务器的时候,可以保证只创建一个Lettuce连接,使所有的线程共享这一个Lettuce连接,这样可以减少创建关闭一个Lettuce连接时候的开销;而且这种方式也是线程安全的,不会出现一个线程通过Lettuce更改Redis服务器中的数据之后而影响另一个线程的情况;

注意

下面是阿里云Redis的引包操作流程:

Spring Data Redis 2.0版本后默认使用Lettuce作为驱动,如您希望切换至Jedis,需要排除Lettuce并主动引入Jedis依赖,示例如下:

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-data-redis</artifactId>
    <exclusions>
        <exclusion>
            <artifactId>lettuce-core</artifactId>
            <groupId>io.lettuce</groupId>
        </exclusion>
    </exclusions>
</dependency>

<dependency>
    <groupId>redis.clients</groupId>
    <artifactId>jedis</artifactId>
    <version>Latest non-RC version</version>
</dependency>
 类似资料: