说明: 在SpringBoot2.x之后,原来使用的jedis被替换了lettuce
jedis: 采用的直连,多个线程操作的话,是不安全的,如果想要避免不安全的,使用jedis pool连接池, 更像 BIO模式
lettuce : 采用netty, 实例可以在多个线程中进行共享, 不存在线程不安全的情况 . 可以减少线程数据了 . 更像 NIO莫斯
1. 构建springboot工程, 配置redis
springboot 所有的配置类,都有一个自动配置类; RedisAutoConfiguration
自动配置类都会绑定一个xx.properties(RedisProperties)配置文件, 这个配置文件绑定application.properties
@Bean
@ConditionalOnMissingBean( //可以自定义一个redisTemplate来替换这个默认的
name = {
"redisTemplate"}
)
public RedisTemplate<Object, Object> redisTemplate(RedisConnectionFactory redisConnectionFactory) throws UnknownHostException {
// 默认的redisTemplate没有过多的设置,redis对象都是需要序列化的
// 两个泛型都是Object的类型,后面使用需要强制转换成<String,Object>
RedisTemplate<Object, Object> template = new RedisTemplate();
template.setConnectionFactory(redisConnectionFactory);
return template;
}
@Bean
@ConditionalOnMissingBean //由于String是redis中最常用的类型,所以暗度提出来一个bean
public StringRedisTemplate stringRedisTemplate(RedisConnectionFactory redisConnectionFactory) throws UnknownHostException {
StringRedisTemplate template = new StringRedisTemplate();
template.setConnectionFactory(redisConnectionFactory);
return template;
}
- 1.导入依赖
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>
- 2.配置连接
spring.redis.host=127.0.0.1
spring.redis.port=6379
- 3.测试
@Autowired
private RedisTemplate redisTemplate;
@Test
void contextLoads() {
redisTemplate.opsForValue().set("key1","binhaizhijun");
System.out.println(redisTemplate.opsForValue().get("key1"));
}
redisTemplate中的opsForXxx(),可以操作不同的数据类型,api和redis的指令是一样的;
除了基本的操作,常用的方法都可以直接通过redisTemplate操作,比如上午和基本的CRUD
获取redis的连接对象如下:
RedisConnection connection = redisTemplate.getConnectionFactory().getConnection();
connection.flushAll();
connection.flushDb();
2.自定义RedisTemplate
redis在存储对象时,如果对象没有序列化,会报错 Failed to serialize object using DefaultSerializer;
(通常企业开发中会存储json串); 所以一般实体类需要实现序列化接口;
Redis默认使用的是jdk默认的序列化方式, 如果需要改变序列化方式,需要自定义
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;
/**
* @ProjectName: qun-redis
* @Package: com.qun.config
* @ClassName: RedisConfig
* @Description: redisTemplate 序列化的配置类
* @Author: 滨海之君
* @CreateDate: 2021/3/2 22:06
*/
@Configuration
public class RedisConfig {
@Bean
@SuppressWarnings("all")
public RedisTemplate<String,Object> redisTemplate(RedisConnectionFactory factory){
RedisTemplate<String, Object> template = new RedisTemplate<>();
template.setConnectionFactory(factory);
Jackson2JsonRedisSerializer jackson2JsonRedisSerializer = new Jackson2JsonRedisSerializer(Object.class);
ObjectMapper objectMapper = new ObjectMapper();
objectMapper.setVisibility(PropertyAccessor.ALL, JsonAutoDetect.Visibility.ANY);
objectMapper.enableDefaultTyping(ObjectMapper.DefaultTyping.NON_FINAL);
jackson2JsonRedisSerializer.setObjectMapper(objectMapper);
StringRedisSerializer stringRedisSerializer = new StringRedisSerializer();
// key采用String的序列化方式
template.setKeySerializer(stringRedisSerializer);
// hash的key采用String的序列化方式
template.setHashKeySerializer(stringRedisSerializer);
//value序列化方式采用jackson
template.setValueSerializer(jackson2JsonRedisSerializer);
// hash的value序列化方式采用jackson
template.setHashValueSerializer(jackson2JsonRedisSerializer);
template.afterPropertiesSet();
return template;
}
}