报错如下:
[2024-01-26 01:23:57,857] Artifact yicai-base-all:war exploded: Deploy took 69,024 milliseconds
#
# There is insufficient memory for the Java Runtime Environment to continue.
# Native memory allocation (malloc) failed to allocate 1560176 bytes for Chunk::new
# An error report file with more information is saved as:
# C:\server\apache-tomcat-8.5_ycg\bin\hs_err_pid25716.log
#
# Compiler replay data is saved as:
# C:\server\apache-tomcat-8.5_ycg\bin\replay_pid25716.log
Disconnected from the target VM, address: '127.0.0.1:52503', transport: 'socket'
Disconnected from server
解决方案:
1:增加JVM内存: 修改Tomcat的启动脚本,增加JVM的最大堆内存。在Tomcat的启动脚本(例如catalina.bat
或catalina.sh
)中,找到Java启动命令,通常以-Xmx
参数设置最大堆内存。例如:
set CATALINA_OPTS=-Xmx1024m -Xms512m
或者:
export CATALINA_OPTS="-Xmx1024m -Xms512m"
众所周知,堆内存默认大小是物理内存的1/64,而堆最大内存为物理内存的1/4,因此只需要适当提升堆内存大小即可,但是注意不要增加过多,避免影响到其他的应用程序。
2:检查系统内存:确保系统中有足够的可用内存,以便Java虚拟机可以分配所需的堆内存。你可以通过操作系统的监控工具或命令来查看系统内存的使用情况。最有效的办法是,直接按住CTRL+SHIFT+ESC三个按键,可以调出任务管理器,查看内存使用情况,可将一些暂时使用不到的应用关闭缓解内存压力。
3:考虑优化应用程序: 如果内存问题持续存在,可能需要优化应用程序的内存使用。这可能包括查找内存泄漏,减少不必要的对象创建,或者调整应用程序的配置以降低内存需求。
4:万金油:电脑和idea都重启一遍。
注*即使是万不得已的情况下,也尽量少的去修改jvm的参数,虽然确实可以解决问题,但是风险很大,切记,切记。