为了账号安全,请及时绑定邮箱和手机立即绑定

大佬们遇到过这个问题吗?使用redis如何防止内存泄露,大佬们有什么好的建议?

大佬们遇到过这个问题吗?使用redis如何防止内存泄露,大佬们有什么好的建议?

MMTTMM 2019-06-09 10:37:52
我在使用swoole开发即时通讯软件的过程中,发现swoole的worder进程中,使用redis操作会导致内存泄露,并且在不同的操作系统中,内存泄露的大小不同。测试代码如下:<?php$server=newswoole_websocket_server("0.0.0.0",4096);$redis=new\Redis();$redis->connect('127.0.0.1',20002);$server->set(array('worker_num'=>1,'daemonize'=>0,'max_request'=>0,'task_worker_num'=>1));$server->on('workerStart',function($ser,$worker_id){});$server->on('task',function($serv,$task_id,$from_id,$msgs){});$server->on('finish',function($serv,$task_id,$data){//print_r($data);});$server->on('open',function(swoole_websocket_server$server,$request){//echo"server:handshakesuccesswithfd{$request->fd}\n";});$server->on('message',function(swoole_websocket_server$server,$frame)use($redis){echo"receivefrom{$frame->fd}:{$frame->data},opcode:{$frame->opcode},fin:{$frame->finish}\n";$redis->incr('test');$server->push($frame->fd,"thisisserver");});$server->on('close',function($ser,$fd){//echo"client{$fd}closed\n";});$server->start();测试过程swoole版本:4.2.12redis:3.1.15测试工具:jemeter测试线程:2000循环次数:5监控:top命令,或者dockerstats命令监控内存使用情况随着压测的进行,内存不断累积,即时中断链接,内存也没有释放,反复压测,会导致worker进程挂掉重启。结论发现经过测试,我发现,当操作系统是centos7.2的时候,内存激增幅度很大,每一轮压测会导致上百M的累积,而当操作系统是alpinelinux3.4的时候,内存增幅相对会小很多,没一轮压测只会导致5M左右的累积。疑问有其他同学碰到这个问题,有没有解决方案?
查看完整描述

2 回答

?
潇湘沐

TA贡献1816条经验 获得超6个赞

如何解决:

  1. 缓存空对象
    存储层不命中,扔将空对象保存到缓存层。
    适用场景:数据频繁变化、实时性高
    带来问题:
    a.缓存了空值,会占用内存空间;可以设置较短过期时间,自动剔除。
    b.数据不一致,若存储层添加了此数据,有短暂不一致;可主动清除掉缓存的空对象。

  2. 布隆过滤器
    在访问缓存层和数据层之前将存在的key用布隆过滤器提前保存起来,做第一层拦截。
    适用场景:大用户集,实时性要求较低的场景,如有几亿的数据集,每隔一段时间会新增用户进去,在更新之前新用户的访问会存在缓存穿透问题。
    缺点:代码维护复杂


查看完整回答
反对 回复 2019-06-09
  • 2 回答
  • 0 关注
  • 680 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信