我在使用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个赞
如何解决:
缓存空对象
存储层不命中,扔将空对象保存到缓存层。
适用场景:数据频繁变化、实时性高
带来问题:
a.缓存了空值,会占用内存空间;可以设置较短过期时间,自动剔除。
b.数据不一致,若存储层添加了此数据,有短暂不一致;可主动清除掉缓存的空对象。布隆过滤器
在访问缓存层和数据层之前将存在的key用布隆过滤器提前保存起来,做第一层拦截。
适用场景:大用户集,实时性要求较低的场景,如有几亿的数据集,每隔一段时间会新增用户进去,在更新之前新用户的访问会存在缓存穿透问题。
缺点:代码维护复杂
添加回答
举报
0/150
提交
取消