Redisson Map踩坑姿势

本文分享了在使用Java的Redisson客户端时遇到的问题,包括RMapCache内存泄露问题,详细解释了EvictionTask与Netty ScheduleTask的关系,以及如何避免内存占用。另外,还提到了Redisson Map在宕机后可能导致Redis存储容量泄露的情况,以及RMap过期时间设置的注意事项。
摘要由CSDN通过智能技术生成

使用Java的Redisson客户端时,踩了一些坑,分享再次,供大家参考。

因此引发的一次故障及排查过程参见: 记一次线上“内存泄露”故障

 

  • RMapCache的坑

RMapCache的坑要从Redisson中Map结构的元素淘汰机制说起,详见 Redisson元素淘汰,为了能够实现对Map中每个元素单独设定 有效时间 和 最长闲置时间,Redisson会创建很多的EvictionTask【由Redisson的EvictionScheduler持有】来执行元素淘汰操作,这些Task实际是交给netty执行ScheduleTask【由netty的NioEventLoop持有】。

    坑一:当大面积使用带有元素淘汰机制的Map类型时候(那些Map类型有元素淘汰功能,详见 Redisson元素淘汰),尤其是持续不断的大量新建时,在客户端会创建大量的Task,这些task会持有很多string类型的key。
        ○ EvictionTask持有的task,可以通过显式的调用Map上的destroy()方法释放,如果不显式释放,Redisson的EvictionScheduler持有了EvictionTask会导致内存泄露
        ○ 由于EvictionTask会交给netty进行Schedule,这些task会一直等到擦除任务执行完成后才会释放,这些key也不会释放【即使显示的调用destroy()也没用】。同时,netty的调度本身也会创建很多的task对象(FutureTask、ScheduleTask等),

  • 4
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值