SpringBoot整合Redis
1. 引入依赖pom.xml
<!--redis-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-redis</artifactId>
<version>2.7.3</version>
</dependency>
<dependency>
<groupId>redis.clients</groupId>
<artifactId>jedis</artifactId>
<version>4.2.3</version>
</dependency>
<!--Spring 2.x 集成redis所需要common-pool2 -->
<dependency>
<groupId>org.apache.commons</groupId>
<artifactId>commons-pool2</artifactId>
<version>2.11.1</version>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
<version>2.7.3</version>
<scope>compile</scope>
</dependency>
<!-- fastJson -->
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>fastjson</artifactId>
<version>2.0.14</version>
</dependency>
2. application.properties添加配置
#Redis服务器地址
spring.redis.host=192.168.47.33
#Redis服务器连接端口
spring.redis.port=6379
#Redis数据库索引(默认位0)
spring.redis.database=0
#连接超时时间(毫秒)
spring.redis.timeout=1800000
#连接池最大连接数(使用负值表示没有限制)
spring.redis.lettuce.pool.max-active=20
#最大阻塞等待时间(复数表示没有限制)
spring.redis.lettuce.pool.max-wait=-1
#连接池中的最大空闲连接
spring.redis.lettuce.pool.max-idle=5
#连接池中的最小空闲连接
spring.redis.lettuce.pool.min-idle=0
3. 测试类
restcontroller和controller区别主要有以下:
1.用Controller配合视图解析器才能返回到指定页面。在对应的方法上加上ResponseBody注解才能返回JSON,XML或自定义mediaType的内容到页面。
2.不可以只用RestController注解Controller,因为这样会让Controller中的内容不能返回jsp页面,而且会直接返回Return里的内容。3.RestController相当于Controller和ResponseBod两者合并起来的作用。
@RestController
@RequestMapping("/redisTest")
public class MyRedisController {
@Resource
RedisTemplate redisTemplate;
@GetMapping("/get")
public String test() {
// 设置值到redis
redisTemplate.opsForValue().set("name", "lucy");
// 从redis获取值
String name = (String) redisTemplate.opsForValue().get("name");
return name;
}
}
登录Redis客户端查看
127.0.0.1:6379> keys *
1) "1"
2) "k1"
3) "k3"
4) "\xac\xed\x00\x05t\x00\x04name"
5) "m1"
6) "k2"
7) "user:1102"
8) "verify:178count"
9) "m2"
其中4) "\xac\xed\x00\x05t\x00\x04name"
为我们插入的key name 但是发现有许多的转义字符
原因:序列化与反序列过程导致
解决:添加RedisConf配置
@EnableCaching
@Configuration
public class RedisConfig extends CachingConfigurerSupport {
@Bean
public RedisTemplate<String, Object> redisTemplate(RedisConnectionFactory redisConnectionFactory) {
RedisTemplate<String, Object> redisTemplate = new RedisTemplate();
redisTemplate.setConnectionFactory(redisConnectionFactory);
FastJsonRedisSerializer<Object> fastJsonRedisSerializer = new FastJsonRedisSerializer(Object.class);
redisTemplate.setValueSerializer(fastJsonRedisSerializer);
// 设置序列化
redisTemplate.setHashValueSerializer(fastJsonRedisSerializer);
redisTemplate.setKeySerializer(new StringRedisSerializer());
redisTemplate.setHashKeySerializer(new StringRedisSerializer());
redisTemplate.afterPropertiesSet();
return redisTemplate;
}
}
127.0.0.1:6379> get name
"\"lucy\""
127.0.0.1:6379> keys *
1) "name"
2) "1"
3) "k1"
4) "k3"
5) "\xac\xed\x00\x05t\x00\x04name"
6) "m1"
7) "k2"
8) "user:1102"
9) "verify:178count"
10) "m2"