Java包装器内存不足

时间:2020-01-06 10:12:36

标签: java wrapper

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

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

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

#********************************************************************
# 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

非常感谢!

2 个答案:

答案 0 :(得分:2)

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

我相信它将使用为您的系统配置的默认值:How is the default Java heap size determined?

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

答案 1 :(得分:0)

因此,您基本上是在问,当您不指定init和max内存时,java会为Java实际分配哪些参数(我相信这些参数会转换为众所周知的-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

然后检查:

  • InitialHeapSize
  • MaxHeapSize
相关问题