1. 概述
1.1 问题描述
用户工程部署在 Tomcat 容器中,若遇到以下问题:
内存溢出错误:java.lang.OutOfMemoryError:Java heap space
FineDataLink 内存占用过高。
Tomcat 后台提示 Memory is over threshold
报错:内存溢出。
想调整 Tomcat 的默认内存。
服务器压力大。
需要将 FineDataLink 工程所在的 Tomcat 服务器内存调大,可参考本文方法解决。
1.2 解决思路
为了避免内存溢出的问题,一方面应适当启用磁盘缓存,另一方面可以根据实际情况调整服务器内存大小。
本文将详细说明如何调整 Tomcat 服务器内存大小。
2. 修改Tomcat服务器内存
本文仅介绍Tomcat类型服务器内存的修改方法。
建议修改的内存相关配置项包括:
内存配置参数 | 说明 | 建议值 |
---|---|---|
Xmx | 指定 Java 堆的最大内存大小 它设置堆的上限,当堆大小达到该值时,JVM将停止分配新的内存并触发垃圾回收 | 建议大于 16G ,但不建议超过 80% 的系统内存 用户可在 健康巡检查看推荐的「堆内内存」大小(Xmx 值) |
Xms | 指定 Java 堆的初始内存大小 它设置堆的初始大小,JVM 会在启动时分配该大小的内存 | 建议 Xms = Xmx |
Xmn | 指定年轻代(Young Generation)的大小 年轻代是堆内存的一部分,用于存放新创建的对象。在垃圾回收过程中,年轻代中的存活对象会被移动到存活区或老年代 | 建议 Xmn = 1/4 * Xmx |
Xss | 单线程使用栈空间 | 建议 Xss = 1024K |
MaxDirectMemorySize | 堆外 NIO 内存,指定直接内存(Direct Memory)的最大大小 直接内存不受 Java 堆大小的限制,通过本地内存直接分配,而不是在 Java 堆中分配 | 建议 2GB,参考值2~4GB 最小 2GB,不限制最大值,但需要考虑用户服务器内存的大小,FineDataLink 使用的内存(BIMax)<= 用户服务器内存 * 7/8 |
Dfineio.read_mem_limit | fineIO 读内存 | 建议 2GB |
Dfineio.write_mem_limit | fineIO 写内存 | 建议 1GB |
2.1 通过startup.bat、startup.sh启动
若 Tomcat 是通过 startup.bat、startup.sh 启动的,参考本章方法修改服务器内存。
2.1.1 Linux
1)进入%Tomcat_HOME%\bin目录。寻找名为setenv.sh的文件。如果文件不存在,可以创建一个新的setenv.sh文件。
注:请确保setenv.sh文件具有可执行权限。如果没有可执行权限,可以使用以下命令进行设置:chmod +x setenv.sh
2)使用文本编辑器打开setenv.sh文件。在文件中添加以下行来设置:
JAVA_OPTS="$JAVA_OPTS -Xms100000M -Xmx100000M -Xmn30000m -Xss1024k"
JAVA_OPTS="$JAVA_OPTS -XX:MaxDirectMemorySize=8g"
JAVA_OPTS="$JAVA_OPTS -Dfineio.read_mem_limit=2"
JAVA_OPTS="$JAVA_OPTS -Dfineio.write_mem_limit=1"
注:以上配置仅为参考配置,您可根据上方表格,依据部署所在服务器情况调整配置参数。
3)保存并关闭 setenv.sh 文件。
4)重启 Tomcat 服务器以使修改生效。管理员登录工程,选择「管理系统>智能运维>负载管理>负载监控」,可以看到实时内存情况,如下图所示:
2.1.2 Windows
1)进入%Tomcat_HOME%\bin目录。寻找名为setenv.bat的文件。如果文件不存在,可以创建一个新的setenv.bat文件。
2)使用文本编辑器打开setenv.bat文件。在文件中添加以下行来设置:
set JAVA_OPTS=%JAVA_OPTS% -Xms100000M -Xmx100000M -Xmn30000m -Xss1024k
set JAVA_OPTS=%JAVA_OPTS% -XX:MaxDirectMemorySize=8g
set JAVA_OPTS=%JAVA_OPTS% -Dfineio.read_mem_limit=2
set JAVA_OPTS=%JAVA_OPTS% -Dfineio.write_mem_limit=1
注:以上配置仅为参考配置,您可根据上方表格,依据部署所在服务器情况调整配置参数。
3)保存并关闭 setenv.bat 文件。
4)重启 Tomcat 服务器以使修改生效。
管理员登录工程,选择「管理系统>智能运维>负载管理>负载监控」,可以看到实时内存情况,如下图所示:
2.2 Tomcat 为安装版本
若通过服务启动 Tomcat,即不是通过 startup.bat、startup.sh 启动 Tomcat 的,参考本章方法解决。
本章以 Win10+Tomcat8+JDK1.8 为例(不同版本可能略有不同请自行处理)。
2.2.1 方法一
1)直接双击 Tomcat 出现在屏幕右下角的系统托盘,打开Java选项卡,修改Initial Memory Pool和Maximum Memory Pool即可。
前者为初始内存,后者为最大内存,最大内存尽量不要超过物理内存的 80% 。
2)修改后,重启 Tomcat 设置生效。
2.2.2 方法二
1)在注册表编辑器中,找到HKEY_LOCAL_MACHINE\SOFTWARE\Wow6432Node\Apache Software Foundation\Procrun 2.0\Tomcat8\Parameters\Java(路径可能有一点差别)。
修改 JvmMs(初始化内存)和 JvmMx(最大内存):
2)重启Tomcat,设置生效。
管理员登录工程,选择「管理系统>智能运维>负载管理>负载监控」,可以看到实时内存情况,如下图所示: