JBoss WildFly 15.0.1 Final 未在具有 2 GB 的 ubuntu 14.04 vServer 上启动:JRE 内存不足

Posted

技术标签:

【中文标题】JBoss WildFly 15.0.1 Final 未在具有 2 GB 的 ubuntu 14.04 vServer 上启动:JRE 内存不足【英文标题】:JBoss WildFly 15.0.1 Final not starting on ubuntu 14.04 vServer with 2 GB: insufficient memory for JRE 【发布时间】:2020-04-05 11:53:40 【问题描述】:

我正在尝试让 JBoss WildFly 15.0.1 Final 在一个相当小的 ubuntu 14.04 vServer 上启动。服务器只有 2 GB 的 RAM。

我多次尝试启动 WildFly,但均未成功。 JVM 似乎需要比我预想的更多的 RAM。

这是控制台输出:

root@t2g55:~# service wildfly start
 * Starting WildFly Application Server wildfly
 * WildFly Application Server failed to start within the timeout allowed.



root@t2g55:~# cat /var/log/wildfly/console.log
=========================================================================

  JBoss Bootstrap Environment

  JBOSS_HOME: /opt/wildfly

  JAVA: /usr/bin/java

  JAVA_OPTS:  -server -Xms768m -Xmx1536m -XX:MetaspaceSize=96M -XX:MaxMetaspaceSize=256m -Djava.net.preferIPv4Stack=true -Djboss.modules.system.pkgs=org.jboss.byteman -Djava.awt.headless=true

=========================================================================

OpenJDK 64-Bit Server VM warning: INFO: os::commit_memory(0x00000000a0000000, 536870912, 0) failed; error='Cannot allocate memory' (errno=12)
#
# There is insufficient memory for the Java Runtime Environment to continue.
# Native memory allocation (mmap) failed to map 536870912 bytes for committing reserved memory.
# An error report file with more information is saved as:
# /opt/wildfly-15.0.1.Final/hs_err_pid1379.log
1379


root@t2g55:~# free
             total       used       free     shared    buffers     cached
Mem:       2097152     258748    1838404         64          0      38644
-/+ buffers/cache:     220104    1877048
Swap:      2097152          0    2097152


root@t2g55:~# java -version
openjdk version "1.8.0_222"
OpenJDK Runtime Environment (build 1.8.0_222-8u222-b10-1~14.04-b10)
OpenJDK 64-Bit Server VM (build 25.222-b10, mixed mode)


root@t2g55:~#

如您所见,我指定了 JAVA_OPTS: -server -Xms768m -Xmx1536m ...,我认为这足以启动 WildFly 服务器。请注意,standalone.xml 有一个定义为 mysql 数据库的数据源。

这是转储 .log 的开始:

root@t2g55:~# cat /opt/wildfly-15.0.1.Final/hs_err_pid1379.log
#
# There is insufficient memory for the Java Runtime Environment to continue.
# Native memory allocation (mmap) failed to map 536870912 bytes for committing reserved memory.
# Possible reasons:
#   The system is out of physical RAM or swap space
#   The process is running with CompressedOops enabled, and the Java Heap may be blocking the growth of the native heap
# Possible solutions:
#   Reduce memory load on the system
#   Increase physical memory or swap space
#   Check if swap backing store is full
#   Decrease Java heap size (-Xmx/-Xms)
#   Decrease number of Java threads
#   Decrease Java thread stack sizes (-Xss)
#   Set larger code cache with -XX:ReservedCodeCacheSize=
# This output file may be truncated or incomplete.
#
#  Out of Memory Error (os_linux.cpp:2757), pid=1379, tid=0x00007f62486c6700
#
# JRE version:  (8.0_222-b10) (build )
# Java VM: OpenJDK 64-Bit Server VM (25.222-b10 mixed mode linux-amd64 compressed oops)
# Failed to write core dump. Core dumps have been disabled. To enable core dumping, try "ulimit -c unlimited" before starting Java again
#

---------------  T H R E A D  ---------------
.
.
.

问题

可以用这么多的内存来解决这个问题,还是我的内存太少了? 我还可以尝试什么?

我真的不希望我的提供者连续使用内存,只是发现 Java、JVM 或任何其他问题...

谢谢

编辑 1:

vServer 提供商使用 OpenVZ 进行虚拟化。

信息:他们只是将我推到 4GB,然后有一次,我让 JBoss 启动并运行。重新启动后,WildFly 再次拒绝启动:同样的事情,内存不足(即使我在 Java 8 和 Java 11 运行时之间切换)。

CMD 启动 JBoss WildFly:sh /opt/wildfly/bin/standalone.sh &,standalone.xml 似乎没问题。我删除了 ExampleDS,评论了三个条目。

【问题讨论】:

developers.redhat.com/blog/2017/03/14/java-inside-docker 可能是那个方向的东西? WildFly 可以在 64M 堆上正常启动,因此如果您使用 -Xmx128M 之类的东西运行 Wildfly 本身应该没问题,问题是您在其上运行的应用程序需要多少。 【参考方案1】:

这确实是 OpenVZ 的服务器虚拟化问题。

引用(德语):

嗨, das 问题 nach bei den user_beancounters、gena​​uer gesagt bei privvmpages、diesewaren > zu gering eingestellt。 https://wiki.openvz.org/UBC_secondary_parameters#privvmpages

Mit freundlichen Grüßen

X先生

翻译:

嗨, 问题出在 user_beancounters 上,也就是 privvmpages,这些设置得太低了。 https://wiki.openvz.org/UBC_secondary_parameters#privvmpages

最好的问候

X先生

我不知道他具体做了什么,但解决了它。

我现在在 2GB 的机器上运行没有任何问题,mysqld + Standalone.sh (WildFly + webapp) 的内存使用量约为 800 MB。

【讨论】:

以上是关于JBoss WildFly 15.0.1 Final 未在具有 2 GB 的 ubuntu 14.04 vServer 上启动:JRE 内存不足的主要内容,如果未能解决你的问题,请参考以下文章

Wildfly/JBOSS 持久性错误 MSC000001:无法启动服务 jboss.persistenceunit

在 JBoss/WildFly 中注入 EntityManager

JBoss EAP,Wildfly,JBoss web和JBoss服务器有什么区别?

Wildfly:意外元素“urn:jboss:domain:4.2server”

jboss升级到WIldfly后fd限制警告

JBoss AS 与 WildFly 8