亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

大佬們遇到過這個問題嗎?使用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 關注
  • 699 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號