too many open files"這條報錯信息,它的實際含義是文件描述符數量超限。用ulimit -a命令打印出各限制值:tcp
查看句柄數
ulimit -a
修改句柄數
vi /etc/security/limits.conf 添加ide
* soft nofile 100000指針
* hard nofile 100000調試
for x in ps -eF| awk '{ print $2 }'
;do echo ls /proc/$x/fd 2> /dev/null | wc -l
$x cat /proc/$x/cmdline 2> /dev/null
;done | sort -n -r | head -n 20 查看文件描述符前20
netstat -tan|awk '$1~/tcp/{print $NF}'|sort|uniq -c|sort -nr 查看當前鏈接情況code
strace -F -p 5351 -T -tt -o trace.log strace狀況進程
-c 統計每一系統調用的所執行的時間,次數和出錯的次數等.
-d 輸出strace關於標準錯誤的調試信息.
-f 跟蹤由fork調用所產生的子進程.
-ff 若是提供-o filename,則全部進程的跟蹤結果輸出到相應的filename.pid中,pid是各進程的進程號.
-F 嘗試跟蹤vfork調用.在-f時,vfork不被跟蹤.
-h 輸出簡要的幫助信息.
-i 輸出系統調用的入口指針.
-q 禁止輸出關於脫離的消息.
-r 打印出相對時間關於,,每個系統調用.
-t 在輸出中的每一行前加上時間信息.
-tt 在輸出中的每一行前加上時間信息,微秒級.
-ttt 微秒級輸出,以秒了表示時間.
-T 顯示每一調用所耗的時間.
-v 輸出全部的系統調用.一些調用關於環境變量,狀態,輸入輸出等調用因爲使用頻繁,默認不輸出.
-V 輸出strace的版本信息.
-x 以十六進制形式輸出非標準字符串
-xx 全部字符串以十六進制形式輸出.
-a column
設置返回值的輸出位置.默認 爲40.
-e expr
指定一個表達式,用來控制如何跟蹤.格式以下: 字符串
lsof -d pid 查看文件描述符cmd