2024.11.14
いまさらNode.jsを知ろう~環境構築も~
2018.02.27
インフラnode.js + socket.io サーバーのメモリリーク対策
坂東です。
nodejs + socket.ioサーバーのメモリリークが止まりません。
以下の手動gcを定期的に実行しても使用量増え続ける。
global.gc();
対策として、cron で週一「forever restart」を実行していました。
socketが1秒くらい瞬断するだけなので運用上問題なく、こんなもんなんだと納得していました。
ただ先日以下の理由でsocket.ioをバージョンアップしたら解消しました。
socket.io-ruby-emitterでsocket.ioサーバーが落ちるならpackageをバージョンアップ
package.jsonをこう。
"socket.io": "1.3.7", "socket.io-redis": "1.0.0",
↓
"socket.io": "1.7.4", "socket.io-redis": "4.0.1",
メモリ使用量の推移はこんなかんじ。ガクッと落ちてるのはnpm installしてrestartしたタイミングです。
綺麗に右肩上がりが止まっていますね。
nodejs + socket.io のメモリリークに悩んでる方は勇気をもってアップデートしてみてはいかがでしょうか。
2.0以上まであげちゃうと1.0と互換がないそうなので注意。
おわり。
【記事への感想募集中!】
記事への感想・ご意見がありましたら、ぜひフォームからご投稿ください!【テクノデジタルではエンジニア/デザイナーを積極採用中です!】
下記項目に1つでも当てはまる方は是非、詳細ページへ!Qangaroo(カンガルー)
【テクノデジタルのインフラサービス】
当社では、多数のサービスの開発実績を活かし、
アプリケーションのパフォーマンスを最大限に引き出すインフラ設計・構築を行います。
AWSなどへのクラウド移行、既存インフラの監視・運用保守も承りますので、ぜひご相談ください。
詳細は下記ページをご覧ください。
最近の記事
タグ検索