最近做了個項目,需要統計linux 下當前socket 的fd數量,總結如下:
Linux中查看socket狀態:
IPV4 cat /proc/net/sockstat
sockets: used 130
TCP: inuse 64 orphan 0 tw 0 alloc 70 mem 3
UDP: inuse 4 mem 0
UDPLITE: inuse 0
RAW: inuse 0
FRAG: inuse 0 memory 0
注:
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:套接字緩沖區使用量
UDP:inuse:正在使用的UDP套接字數量
RAW:
FRAG:使用的IP段數量
IPv6:cat /proc/net/sockstat6
TCP6: inuse 4
UDP6: inuse 0
UDPLITE6: inuse 0
RAW6: inuse 0
FRAG6: inuse 0 memory 0
1)Linux系統下,所有進程允許打開的最大fd數量。查詢語句:
/proc/sys/fs/file-max
2)Linux系統下,所有進程已經打開的fd數量及允許的最大數量。查詢語句:
/proc/sys/fs/file-nr
3)單個進程允許打開的最大fd數量.查詢語句:
ulimit -n
4)單個進程(例如進程id為5454)已經打開的fd.查詢語句:
ls -l /proc/5454/fd/