Spring2.0之后的spring-boot-starter-data-redis存在bug
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>
spring.redis.host=192.168.56.10
spring.redis.port=6379
@Autowired
StringRedisTemplate stringRedisTemplate;
@Test
void contextLoads() {
ValueOperations<String, String> ops =
stringRedisTemplate.opsForValue();
ops.set("key", UUID.randomUUID().toString());
System.out.println(ops.get("key"));;
}
1).由于使用了lettuce作为操作redis的客户端,它使用netty进行网络通信
2).lettuce的bug导致netty对外内存溢出,netty如果没有指定对外内存,就会使用-Xmx配置的内存
可以通过-Dio.netty.maxDirectMemory 设置
解决方案:
不能只使用-Dio.netty.maxDirectMemory去增大堆外内存
1).升级lettuce客户端(官网没有升级)
2).使用jedis
使用jedis
排除lettuce,添加jedis
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-redis</artifactId>
<exclusions>
<exclusion>
<groupId>io.lettuce</groupId>
<artifactId>lettuce-core</artifactId>
</exclusion>
</exclusions>
</dependency>
<!-- 不需要加版本号,springboot中有jedis ,已经管理好版本 -->
<dependency>
<groupId>redis.clients</groupId>
<artifactId>jedis</artifactId>
</dependency>