为什么Tomcat内存没有增加

时间:2016-11-19 09:22:32

标签: java tomcat memory webserver tomcat8

安装了应用程序的服务器有1G内存。但是当tomcat启动时它只启动500MB

我创建了setenv.sh,如下所示

export CATALINA_OPTS="$CATALINA_OPTS -Xms2024m"
export CATALINA_OPTS="$CATALINA_OPTS -Xmx3024m"

我需要知道它为什么不盯着2GB

当我想启动tomcat时使用以下命令

./catalina.sh start

在CATALINA.SH下面的代码已经退出,它将调用setenv.sh

if [ -r "$CATALINA_BASE/bin/setenv.sh" ]; then
  . "$CATALINA_BASE/bin/setenv.sh"
elif [ -r "$CATALINA_HOME/bin/setenv.sh" ]; then
  . "$CATALINA_HOME/bin/setenv.sh"
fi

我已经检查过tomcat日志,提到它是以2024m开始但它仍然没有使用2G Ram

INFO [main] org.apache.catalina.startup.VersionLoggerListener.log Command line argument: -Xms2024m
INFO [main] org.apache.catalina.startup.VersionLoggerListener.log Command line argument: -Xmx3024m
INFO [main] org.apache.catalina.startup.VersionLoggerListener.log Command line argument: -Dcatalina.base=/usr/share/tomcat

2 个答案:

答案 0 :(得分:4)

tomcat是否从setenv.sh开始?环境变量继承到子进程中,不会影响父进程,因此以下内容不起作用:

$ ./setenvh.sh
$ ./start-tomcat.sh

因为shell是父进程,所以变量在子进程(setenv.sh)中设置,然后在该脚本退出时“忘记”。

以下内容可行:

$ . ./setenv.sh
$ ./start-tomcat.sh

因为.在当前shell中执行setenv.sh并在子进程中启动tomcat之前修改了变量。

答案 1 :(得分:1)

最好的方式

在linux中运行

 export _JAVA_OPTIONS="-Xms2024m -Xmx3024m"

停止启动tomcat

./catalina.sh stop
Using CATALINA_BASE:   /usr/tomcat
Using CATALINA_HOME:   /usr/tomcat
Using CATALINA_TMPDIR: /usr/tomcat/temp
Using JRE_HOME:        /usr/lib/jvm/java-8-oracle
Using CLASSPATH:       /usr/share/tomcat/bin/bootstrap.jar:/usr/tomcat/bin/tomcat-juli.jar
Picked up _JAVA_OPTIONS: -Xms2024m -Xmx3024

当你在日志中停止tomcat时它会提到

Picked up _JAVA_OPTIONS: -Xms2024m -Xmx3024

开始

./catalina.sh start
Using CATALINA_BASE:   /usr/tomcat
Using CATALINA_HOME:   /usr/tomcat
Using CATALINA_TMPDIR: /usr/tomcat/temp
Using JRE_HOME:        /usr/lib/jvm/java-8-oracle
Using CLASSPATH:       /usr/share/tomcat/bin/bootstrap.jar:/usr/tomcat/bin/tomcat-juli.jar

并通过以下命令可以检查JAVA环境已更改

java -XX:+PrintFlagsFinal -version | grep -iE 'HeapSize|PermSize|ThreadStackSize'

结果

 Picked up _JAVA_OPTIONS: -Xms2024m -Xmx3024m
         intx CompilerThreadStackSize                   = 0                                   {pd product}
        uintx ErgoHeapSizeLimit                         = 0                                   {product}
        uintx HeapSizePerGCThread                       = 87241520                            {product}
        uintx InitialHeapSize                          := 2122317824                          {product}
        uintx LargePageHeapSizeThreshold                = 134217728                           {product}
        uintx MaxHeapSize                              := 3170893824                          {product}
         intx ThreadStackSize                           = 1024                                {pd product}
         intx VMThreadStackSize                         = 1024                                {pd product}
    java version "1.8.0_111"
    Java(TM) SE Runtime Environment (build 1.8.0_111-b14)
    Java HotSpot(TM) 64-Bit Server VM (build 25.111-b14, mixed mode)