java.lang.OutOfMemoryError:启动wildfly时无法创建新的本机线程

时间:2015-06-21 04:55:21

标签: java out-of-memory server wildfly

我想在我的虚拟服务器上启动一个野生动物。每次运行./wildfly/bin/standalone.sh时,我都会在引导时遇到以下错误:

MSC000001: Failed to start service jboss.ironjacamar.idle-remover: org.jboss.msc.service.StartException in service jboss.ironjacamar.idle-remover: java.lang.OutOfMemoryError: unable to create new native thread
    at org.jboss.as.connector.subsystems.jca.IdleRemoverService.start(IdleRemoverService.java:53)
    at org.jboss.msc.service.ServiceControllerImpl$StartTask.startService(ServiceControllerImpl.java:1948) [jboss-msc-1.2.2.Final.jar:1.2.2.Final]
    at org.jboss.msc.service.ServiceControllerImpl$StartTask.run(ServiceControllerImpl.java:1881) [jboss-msc-1.2.2.Final.jar:1.2.2.Final]
    at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142) [rt.jar:1.8.0_45]
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617) [rt.jar:1.8.0_45]
    at java.lang.Thread.run(Thread.java:745) [rt.jar:1.8.0_45]
Caused by: java.lang.OutOfMemoryError: unable to create new native thread
    at java.lang.Thread.start0(Native Method) [rt.jar:1.8.0_45]
    at java.lang.Thread.start(Thread.java:714) [rt.jar:1.8.0_45]
    at java.util.concurrent.ThreadPoolExecutor.addWorker(ThreadPoolExecutor.java:950) [rt.jar:1.8.0_45]
    at java.util.concurrent.ThreadPoolExecutor.execute(ThreadPoolExecutor.java:1357) [rt.jar:1.8.0_45]
    at java.util.concurrent.Executors$DelegatedExecutorService.execute(Executors.java:668) [rt.jar:1.8.0_45]
    at org.jboss.jca.core.connectionmanager.pool.idle.IdleRemover.start(IdleRemover.java:137)
    at org.jboss.as.connector.subsystems.jca.IdleRemoverService.start(IdleRemoverService.java:51)
    ... 5 more

ulimit -a让我得到以下信息:

core file size          (blocks, -c) unlimited
data seg size           (kbytes, -d) unlimited
scheduling priority             (-e) 0
file size               (blocks, -f) unlimited
pending signals                 (-i) 385262
max locked memory       (kbytes, -l) 64
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) 385262
virtual memory          (kbytes, -v) unlimited
file locks                      (-x) unlimited

正如您所看到的,虚拟内存是无限的,最大的用户进程非常多 我按照in this post所述启动jvm时使用-Xss256kb增加/减少了堆栈大小但没有任何成功。
对于每个子系统,在standalone.xml中将max-threads增加50也不起作用(描述为in this post)。
你还有其他想法如何解决这个问题吗?

Java版本

java version "1.8.0_45"
Java(TM) SE Runtime Environment (build 1.8.0_45-b14)
Java HotSpot(TM) 64-Bit Server VM (build 25.45-b02, mixed mode)

4 个答案:

答案 0 :(得分:1)

要修复OutOfMemoryError,请使用-Xmx2048m开关启动您的java进程。

希望这有帮助。

答案 1 :(得分:0)

你的盒子有多少CPU? IIRC,wildfly中的一些线程池正在创建与CPU数量相关的线程,因此如果你有非常多的CPU,那可能就是一个问题。虽然它说它无法创建新线程,但它可能仍然是内存问题(而不是max user processes),因为每个线程也需要内存。

否则,您可能会尝试创建堆转储以找出wildfly创建的线程数。

也许完整的启动日志也可以提供更多信息

答案 2 :(得分:0)

您需要增加允许的打开文件数。错误的关键是unable to create new native thread。在Linux上,如果你执行应该修复它的ulimit -n 8192

答案 3 :(得分:0)

在 Linux 系统上,如果您的系统支持更高的值,请尝试增加 vm.max_map_count sysctl 值。 内存映射计数的默认操作系统限制通常较低 - 65530。

在 CentOS 或 RHEL 机器上,

sysctl -w vm.max_map_count=131072

要使此更改永久化, echo "vm.max_map_count = 131072" >> /etc/sysctl.conf