我正在使用 tomcat 7 和 java 1.7 的 debian 服务器上工作。这是一个接收多个 TCP 连接的应用程序,每个 TCP 连接都是一个由 java 进程打开的文件。
看着 /proc/pid of java/fd
我发现有时打开文件的数量超过1024,当发生这种情况时,我在catalina.out
中找到记录堆栈跟踪 _SocketException: Too many open files_
我发现的关于这个错误的一切,人们都引用了 ulimit,我已经改变了这个东西并且错误不断发生。这是配置:
在 /etc/security/limits.conf
root soft nofile 8192
root hard nofile 8192
在
/etc/sysctl.conf
fs.file-max = 300000
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) 16382
max locked memory (kbytes, -l) 64
max memory size (kbytes, -m) unlimited
open files (-n) 8192
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) unlimited
virtual memory (kbytes, -v) unlimited
file locks (-x) unlimited
但是,当我检查 java 进程的限制时,它只有 1024
在
/proc/pid of java/limits
Limit Soft Limit Hard Limit Units
Max cpu time unlimited unlimited seconds
Max file size unlimited unlimited bytes
Max data size unlimited unlimited bytes
Max stack size 8388608 unlimited bytes
Max core file size 0 unlimited bytes
Max resident set unlimited unlimited bytes
Max processes 32339 32339 processes
Max open files 1024 1024 files
Max locked memory 65536 65536 bytes
Max address space unlimited unlimited bytes
Max file locks unlimited unlimited locks
Max pending signals 32339 32339 signals
Max msgqueue size 819200 819200 bytes
Max nice priority 0 0
Max realtime priority 0 0
Max realtime timeout unlimited unlimited us
如何增加
Max open files
的数量对于java进程?
最佳答案
我只是把线ulimit -n 8192
在 catalina.sh 里面,所以当我做 catalina start
, java 以上面指定的限制运行。
关于socketexception - 打开的文件太多( ulimit 已更改),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13988780/