美文网首页程序员
socket(SOCK_DRAGM): Too many ope

socket(SOCK_DRAGM): Too many ope

作者: Dawsen | 来源:发表于2018-03-28 09:15 被阅读0次

    问题: socket(SOCK_DRAGM): Too many open files错误导致进程挂掉

    1. 调试:查看socket的连接数

    root@OpenWrt:/tmp# cat /proc/net/sockstat
    sockets: used 87
    TCP: inuse 9 orphan 0 tw 0 alloc 14 mem 0
    UDP: inuse 11 mem 2
    UDPLITE: inuse 0
    RAW: inuse 0
    FRAG: inuse 0 memory 0
    
    Ipv6:
    cat /proc/net/sockstat6
    

    2.说明:

    sockets: used:已使用的所有协议套接字总量
    TCP: inuse:正在使用(正在侦听)的TCP套接字数量。其值≤ netstat –lnt | grep ^tcp | wc –l
    TCP: orphan:无主(不属于任何进程)的TCP连接数(无用、待销毁的TCP socket数)
    TCP: tw:等待关闭的TCP连接数。其值等于netstat –ant | grep TIME_WAIT | wc –l
    TCP:alloc(allocated):已分配(已建立、已申请到sk_buff)的TCP套接字数量。其值等于netstat –ant | grep ^tcp | wc –l
    TCP:mem:套接字缓冲区使用量(单位不详。用scp实测,速度在4803.9kB/s时:其值=11,netstat –ant 中相应的22端口的Recv-Q=0,Send-Q≈400)
    UDP:inuse:正在使用的UDP套接字数量
    RAW:
    FRAG:使用的IP段数量

    3. 导致原因:

    socket创建后,后续程序执行出错,退出函数之前没有关闭socket

    相关文章

      网友评论

        本文标题:socket(SOCK_DRAGM): Too many ope

        本文链接:https://www.haomeiwen.com/subject/eatycftx.html