一、Jedis
什么是Jedis?
我们如果要使用Java来操作Redis,就要使用Jedis
Jedis是Redis官方推荐的java连接开发工具,使用java操作Redis中间件。
1、导入依赖
<!-- jedis -->
<dependency>
<groupId>redis.clients</groupId>
<artifactId>jedis</artifactId>
<version>4.2.3</version>
</dependency>
<!-- fastjson -->
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>fastjson</artifactId>
<version>1.2.80</version>
</dependency>
2、编码测试
- 连接数据库
- 操作命令
- 断开连接
public class TestPing {
public static void main(String[] args) {
//new Jedis对象
Jedis jedis = new Jedis("127.0.0.1",6379);
//jedis所有方法都是redis里的命令
System.out.println(jedis.ping());
}
}
输出:
常用的API
String
List
Set
Hash
Zset
事务
所有的API命令,就是对应redis中的所有指令
详情见Redis学习(二)之五大基本数据类型和三种特殊数据类型
二、SpringBoot整合Redis
说明:在SpringBoot2.x 之后,原来使用的jedis被替换成了lettuce
jedis:采用的直连,多个线程操作是不安全的,如果想要避免不安全,使用redis pool连接池。更像BIO模式
lettuce:采用netty,实例可在多个线程中进行共享,不存在线程不安全的情况,可以减少线程数量。更像NIO模式
1、源码分析
@Bean
//该注解表示redisTemplate不存在该默认bean才生效,说明我们可以自定义一个redisTemplate来替换默认的
@ConditionalOnMissingBean(name = "redisTemplate")
@ConditionalOnSingleCandidate(RedisConnectionFactory.class)
public RedisTemplate<Object, Object> redisTemplate(RedisConnectionFactory redisConnectionFactory) {
//默认的 RedisTemplate 没有过多的设置,redis对象都是需要序列化
//两个泛型都是Object,Object的类型,后续使用需要强制转换<String,Object>
RedisTemplate<Object, Object> template = new RedisTemplate<>();
template.setConnectionFactory(redisConnectionFactory);
return template;
}
@Bean
@ConditionalOnMissingBean //由于String是redis中是最常用的,所以单独出来了一个bean
@ConditionalOnSingleCandidate(RedisConnectionFactory.class)
public StringRedisTemplate stringRedisTemplate(RedisConnectionFactory redisConnectionFactory) {
return new StringRedisTemplate(redisConnectionFactory);
}
2、整合
1、导入依赖
<!-- redis -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>
2、配置连接
spring:
redis:
host: 127.0.0.1
port: 6379
database: 0
3、测试
(不包含自定义的配置类和工具类)
测试结果:
为了方便,可以自定义RedisTemplate
配置类和工具类
测试:
测试结果: