zoukankan      html  css  js  c++  java
  • [转]确认是否有socket泄露

    问题定位步骤:
    1、   用root帐户 遍历 /proc/进程ID/fd目录,如果该目录下文件数比较大(如果大于10,一般就属于socket泄漏),根据该进程ID,可以确认该进程ID所对应的名称。
    2、   重启程序恢复服务,以便后续查找问题。
    3、   strace 该程序并记录strace信息。strace –p 进程ID >>/tmp/stracelog.log 2>&1
    4、   查看 /proc/进程ID/fd 下的文件数目是否有增加,如果发现有增加,记录上一个socket编号,停止strace
    5、   确认问题代码的位置。打开/tmp/stracelog.log,从尾部向上查找close(socket编号)所在行,可以确认在该次close后再次创建的socket没有关闭,根据socket连接的server ip可以确认问题代码的位置。


    另一种方法:判断是否有socket泄漏:
    lsof | grep "can't identify protocol"
    如果存在很多,则代表socket泄漏,同时会显示哪个进程使用的sock未关闭。

  • 相关阅读:
    第一阶段站立会议4
    第一阶段站立会议3
    用户场景描述
    第一阶段站立会议2
    第一阶段站立会议1
    第七周进度条
    第十二周工作总结
    寻找水王
    第十一周工作总结
    构建之法阅读笔记05
  • 原文地址:https://www.cnblogs.com/lihaozy/p/2780386.html
Copyright © 2011-2022 走看看