繁体   English   中英

Java 包装器内存不足

[英]Java Wrapper OutofMemory

我有一个在 java 包装器下运行的程序,因为该应用程序必须作为 Windows 服务运行。 但是,我在线程“Thread-5”中遇到异常 java.lang.OutOfMemoryError: Java heap space在每两周运行一次应用程序后。

内存值被注释掉。 这是否意味着允许此应用程序使用的内存没有限制?

我也在检查可能内存泄漏的代码,但是有什么方法可以修改配置以查找原因/防止内存不足错误?

#********************************************************************
# Wrapper Java Properties
#********************************************************************
# Java Application
#  Locate the java binary on the system PATH:
#wrapper.java.command=%JAVA_HOME%\bin\java
#  Specify a specific java binary:
set.JAVA_HOME=%JAVA_HOME%
wrapper.java.command=%JAVA_HOME%\bin\java

# Tell the Wrapper to log the full generated Java command line.
#wrapper.java.command.loglevel=INFO

# Java Main class.  This class must implement the WrapperListener interface
#  or guarantee that the WrapperManager class is initialized.  Helper
#  classes are provided to do this for you.  See the Integration section
#  of the documentation for details.
wrapper.java.mainclass=org.tanukisoftware.wrapper.WrapperSimpleApp

# Java Classpath (include wrapper.jar)  Add class path elements as
#  needed starting from 1
wrapper.java.classpath.1=../lib/wrapper.jar
wrapper.java.classpath.2=%JAVA_HOME%\lib\tools.jar
wrapper.java.classpath.3=C:\daifuku\wms\tomcat\webapps\wms\WEB-INF\classes
wrapper.java.classpath.4=C:\daifuku\wms\tomcat\webapps\wms\WEB-INF\lib\*.jar
wrapper.java.classpath.5=C:\daifuku\wms\tomcat\lib\comm.jar
wrapper.java.classpath.6=C:\daifuku\wms\tomcat\lib\servlet-api.jar
wrapper.java.classpath.7=C:\daifuku\wms\tomcat\lib\jsp-api.jar


# Java Library Path (location of Wrapper.DLL or libwrapper.so)
wrapper.java.library.path.1=%JAVA_HOME%\jre\lib

# Java Bits.  On applicable platforms, tells the JVM to run in 32 or 64-bit mode.
wrapper.java.additional.auto_bits=TRUE

# Java Additional Parameters
wrapper.java.additional.1=

# Initial Java Heap Size (in MB)
#wrapper.java.initmemory=64

# Maximum Java Heap Size (in MB)
#wrapper.java.maxmemory=512

# Application parameters.  Add parameters as needed starting from 1
wrapper.app.parameter.1=XXX

非常感谢!

这是否意味着允许此应用程序使用的内存没有限制?

我相信它将使用为您的系统配置的默认值: 默认 Java 堆大小是如何确定的?

由于您提到在运行您的应用程序几周后出现问题,因此您很可能存在内存泄漏。 我建议您使用 JvisualVm 为您的 Java 包装过程进行转储,然后使用 Mat 分析器https://www.eclipse.org/mat/分析转储。

所以你基本上是在问当你没有指定 init 和 max memory 时 java 实际分配了哪些 Heap 参数(我相信这会转化为众所周知的-Xmx-Xms

一般来说,它依赖于系统,算法也改变了很多次,所以可以肯定的是,你实际上应该检查你的系统:

java -XX:+PrintFlagsFinal -version | grep HeapSize // or run you application with that flag if you wish
// or on windows 
java -XX:+PrintFlagsFinal -version | findstr HeapSize

然后检查:

  • 初始堆大小
  • 最大堆大小

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM