Too many open files報錯處理
檔案控制程式碼申請太多導致異常 Too many open files
產生原因:
too many open files(開啟的檔案過多)是Linux系統中常見的錯誤,從字面意思上看就是說程式開啟的檔案數過多,不過這裡的files不單是檔案的意思,也包括開啟的通訊連結(比如socket),正在監聽的埠等等,所以有時候也可以叫做控制程式碼(handle),這個錯誤通常也可以叫做控制程式碼數超出系統限制。
引起的原因就是程式在某個時刻開啟了超過系統限制的檔案數量以及通訊連結數,透過命令ulimit -a可以檢視當前系統設定的最大控制程式碼數是多少:
open files那一行就代表系統目前允許單個程式開啟的最大控制程式碼數,這裡是1024。
使用命令lsof -p 程式id可以檢視單個程式所有開啟的檔案詳情,使用命令lsof -p 程式id | wc -l可以統計程式開啟了多少檔案:
解決辦法:
1、命令方式增大允許開啟的檔案數
ulimit -n 2048
可以將此命令寫入環境變數配置檔案中,每次登陸會話都會執行一遍
這樣就可以把當前使用者的最大允許開啟檔案數量設定為2048了,但這種設定方法在重啟後會還原為預設值。
ulimit -n命令非root使用者只能設定到4096。
想要設定到8192需要sudo許可權或者root使用者。
2、修改系統配置檔案增大允許開啟的檔案數
vim /etc/security/limits.conf
#在最後加入
* soft nofile 4096
* hard nofile 4096
或者只加入
* - nofile 8192
最前的 * 表示所有使用者,可根據需要設定某一使用者,例如
hadoop soft nofile 8192
hadoop hard nofile 8192
注意”nofile”項有兩個可能的限制措施。就是項下的hard和soft。 要使修改過得最大開啟檔案數生效,必須對這兩種限制進行設定。 如果使用”-“字元設定, 則hard和soft設定會同時被設定。
本作品採用《CC 協議》,轉載必須註明作者和本文連結