事故原因:

运维报告redis内存直线上升,然后查询发现都是setrange操作,review代码,没法发现setrange操作

代码如下:

redisTemplate.opsForValue().set(groupid+xxxResult.getSeriesNo(), JSON.toJSONString(xxxRquestDTO),1000*60L)

赶紧查一下api:

set(K key, V value, long offset)

Overwrite parts of key starting at the specified offset with given value.
 
开发的本意设置超时时间,改成这个api:
set(K key, V value, long timeout, TimeUnit unit)
Set the value and expiration timeout for key.
快速上线后问题解决。
 
分析:
1. set(K key, V value, long offset) 这个存储键值是以range的
2.spring重写的这个和set(K key, V value, long timeout, TimeUnit unit) 太容易让人误解了
3.其实中间件封装好了,不需要设置时间单元,但因这次是旧项目改造,直接使用spring-data-redis导致的。

相关文章:

  • 2021-07-08
  • 2022-12-23
  • 2021-12-19
  • 2022-01-09
  • 2022-12-23
猜你喜欢
  • 2022-12-23
  • 2021-12-08
  • 2021-07-27
  • 2021-06-28
  • 2021-06-12
  • 2022-02-02
相关资源
相似解决方案