您好,登錄后才能下訂單哦!
本篇文章為大家展示了Linux 中有哪些常用查詢句柄的命令,內容簡明扼要并且容易理解,絕對能使你眼前一亮,通過這篇文章的詳細介紹希望你能有所收獲。
lsof -n | wc -l
lsof -n|awk '{print $2}'|sort|uniq -c|sort -nr|more
第一列 是 占用句柄數; 第二列 是 進程號 PID;
lsof |grep PID
第一列:進程名稱 第二列:PID 第三列:進程所有者 第四列:文件描述符 第五列:文件類型
第一步:修改linux系統參數。vi /etc/security/limits.conf 添加
* soft nofile 65535 * hard nofile 65535
這里 * 表示所有用戶, 但有的系統不認, 需要具體的用戶名, 比如:
root soft nofile 65535 root hard nofile 65535
第二步: 編輯 etc/pam.d/login , 確保有如下行:
session required pam_limits.so
第三步:修改以后保存,注銷當前用戶,重新登錄
第四步:驗證。 使用 ulimit -Hn 和 ulimit -Sn 命令可以分別查看當前進程用戶的 hard 和 soft 的限制數.
或者當前用戶啟動某個程序后, 通過 cat /proc/<PID>/limits (pid是該進程的, 或者其隨便一個子進程的pid)
ulimit -HSn 65536
簡單的執行這個命令,只有在當前回話有效。如果想永久保存下來,可以修改.bash_profile文件,可以修改 /etc/profile 把上面命令加到最后.
ulimit -a 查看當前用戶的文件句柄限制
ulimit -a
用戶級別的句柄數限制修改。
修改 /etc/security/limits.conf 增加下面的代碼: 用戶名(或者用*表示所有用戶) soft nofile 65535
用戶名 hard nofile 65535 有兩種限制,一種是soft軟限制,在數目超過軟限制的時候系統會給出warning警告,但是達到hard硬限制的時候系統將拒絕或者異常了。 修改之后可能需要重啟shell生效。
系統級別的句柄數限制修改。
sysctl -w fs.file-max 65536
或者
echo "65536" > /proc/sys/fs/file-max
兩者作用是相同的,前者改內核參數,后者直接作用于內核參數在虛擬文件系統(procfs, psuedo file system)上對應的文件而已。 可以用下面的命令查看新的限制
sysctl -a | grep fs.file-max
或者
cat /proc/sys/fs/file-max
修改內核參數
/etc/sysctl.conf echo "fs.file-max=65536" >> /etc/sysctl.conf sysctl -p
查看系統總限制 命令:
cat /proc/sys/fs/file-max
查看整個系統目前使用的文件句柄數量命令:
cat /proc/sys/fs/file-nr
查看某個進程開了哪些句柄 :
lsof -p pid
某個進程開了幾個句柄 :
lsof -p pid |wc -l
也可以看到某個目錄 /文件被什么進程占用了,顯示已打開該目錄或文件的所有進程信息 :
lsof path/filename
上述內容就是Linux 中有哪些常用查詢句柄的命令,你們學到知識或技能了嗎?如果還想學到更多技能或者豐富自己的知識儲備,歡迎關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。