目录:
Redis从入门到精通(一):缓存
Redis从入门到精通(二):分布式锁以及缓存相关问题
Redis从入门到精通(三):Redis持久化算法以及内存淘汰策略
Redis从入门到精通(四):Redis常用数据结构以及指令
Redis从入门到精通(五):Redis6整合SpringBoot2.x+Mybatis+SpringCache
Redis从入门到精通(六):Redis高可用原理
Redis从入门到精通(七):跳跃表的简介与实现
Redis从入门到精通(八):Redis新特性
java客户端
在redis中,适配了许多语言,如java,python,nodejs等。我们是java开发,就使用java的redis客户端。
redis有两种客户端供java使用:jedes, lettuce
jedis:
- 直连模式,多线程中不安全,使用连接池进行处理连接。
- 命令更加全面
- 暴露底层API
- 不支持异步操作,阻塞I/O
lettuce:
- 线程安全,可以异步
- 基于Netty的事件驱动
我们现在用的都是lettuce版本的,因此这里选用jdk1.8+lettuce+idea进行整合。
pom.xml
Redis.template
我这里是报错了的,因为连接问题。
解决方法:
- 关闭防火墙或者设置安全组
- 更改
redis.conf
文件
当然,也可以自己写配置文件,不改人家的。
我们看一下RedisTemplate
这个类:
这些方法其实和我们之前说的各种基本方法类似,只不过封装了函数而已。而我们还有一个类是StringRedisTemplate
,这个类实际上是继承了RedisTemplate
的。
但是我们看二者的序列化方式:
可以看出来,StringRedisTemplate
使用了String类的序列化方式,而RedisTemplate
利用的是JDK本身的序列化方式。而我们序列化的方式不同,造就了一些使用或者特性的不同。
- S与R的数据不互通。由于序列化方式不同,相同key的二进制代码不同,因此存入redis的key不同,造就了数据不互通。
- 由于序列化方式不同,因此效率不同。JDK原带的序列化方式效率低下。
- JDK序列化可能会产生乱码,且需要实现Serializable接口
所以可以看到,我们最好不用原生的JDK序列化方式,在使用Redis做序列化的时候,我们可以使用多种方法代替原生序列化。
- 简单的
k-v
使用StringRedisTemplate
替代 - 使用Jackson2JsonRedisSerializer。配置直接拷贝即可,不用修改。
import com.fasterxml.jackson.annotation.JsonAutoDetect; import com.fasterxml.jackson.annotation.PropertyAccessor; import com.fasterxml.jackson.databind.ObjectMapper; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; import org.springframework.data.redis.connection.RedisConnectionFactory; import org.springframework.data.redis.core.RedisTemplate; import org.springframework.data.redis.serializer.Jackson2JsonRedisSerializer; import org.springframework.data.redis.serializer.StringRedisSerializer; @Configuration public class RedisSerializableConfiguration { @Bean public RedisTemplate<Object,<