今天使用jrockit啟動大量線程時(2026條線程)發生錯誤:
Java代碼
Error starting thread: Resource temporarily unavailable
經過深入查詢,排除了記憶體,控制代碼數等問題. 並且切換至root使用者開啟大量線程時沒有問題。試著調整ulimit各項參數,最後發現是"max user processes "參數有問題,通過root使用者調整大小至 12000,線程數也隨著增大.
Java代碼
root@blog:/home/badqiu# 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) 143360
max locked memory (kbytes, -l) 32
max memory size (kbytes, -m) unlimited
open files (-n) 2048
pipe size (512 bytes, -p) 8
POSIX message queues (bytes, -q) 819200
real-time priority (-r) 0
stack size (kbytes, -s) 8192
cpu time (seconds, -t) unlimited
max user processes (-u) 2046
virtual memory (kbytes, -v) unlimited
file locks (-x) unlimited
在linux系統內生效。
vi /etc/security/limits.conf
Java代碼
* soft nproc 12000
* hard nproc 12000
nproc就是"max user processes",完整描述是: nproc - max number of processes
參數含義:
單個使用者可以啟動的線程數,因為進程也會啟動一個線程,所以也間接對進程數有限制。
注意:
該參數只對普通使用者有用,root使用者不在此限制。 所以用root使用者可以啟動幾萬個線程,無法重現這個問題.