這個問題的出現原因是system對程序打開files數量的限制問題。
用 ulimit -a 命令可以查看
[root@5 ~]# ulimit -a
core file size (blocks, -c) 0
data seg size (kbytes, -d) unlimited
scheduling priority (-e) 0
file size (blocks, -f) unlimited
pending signals (-i) 4096
max locked memory (kbytes, -l) 32
max memory size (kbytes, -m) unlimited
open files (-n) 1024
pipe size (512 bytes, -p) 8
POSIX message queues (bytes, -q) 819200
real-time priority (-r) 0
stack size (kbytes, -s) 10240
cpu time (seconds, -t) unlimited
max user processes (-u) 4096
virtual memory (kbytes, -v) unlimited
file locks (-x) unlimited
可以看出,對open files的限制數是1024,我們可以通過修改這個值來增加可以打開的文件數。
******************************************************************
臨時修改:
將其改為2048,用 ulimit -n 2048.
當你把open files的值增大到一定程度,你的Too many open files就不會再出現了。
******************************************************************
若要 長久 改變這兩個參數值,就要修改/ect/security/limits.conf,在文件中加上兩行:
代碼如下:
* - nofile 65535
* - nproc 65535
注:這行設置了每個用戶的默認打開文件數為2048。 注意"nofile"項有兩個可能的限制措施。就是項下的hard和soft。 要使修改過得最大打開文件數生效,必須對這兩種限制進行設定。 如果使用"-"字符設定, 則hard和soft設定會同時被設定。
硬限制表明soft限制中所能設定的最大值。 soft限制指的是當前系統生效的設置值。 hard限制值可以被普通用戶降低。但是不能增加。 soft限制不能設置的比hard限制更高。 只有root用戶才能夠增加hard限制值。
當增加文件限制描述,可以簡單的把當前值雙倍。 例子如下, 如果你要提高默認值1024, 最好提高到2048, 如果還要繼續增加, 就需要設置成4096。
最後用ulimit -a再次查看,open files的值,沒什麼問題的話,就已經改過來了。
******************************************************************
-------------------------------------------------------------
經過以上設置,退出shell再次登錄,還是不生效,來點絕的
到//etc/profile下,加入一行ulimit -SHn 51200 (注意裡面已經有一條關於ulimit的設置)
到rc.local下,加入一行 ulimit -SHn 51200 (不知這條有沒有必要,其實我還沒加)
ulimit -S -c 0 > /dev/null 2>&1
這條語句設置了對軟件資源和對core文件大小的設置