重点说明:

1、下面的语句是执行语句(“process-activiti-0.0.1-SNAPSHOT.jar”为打包项目jar,自己使用的时候做替换就可以了,在对应的项目文件夹下面执行!)

nohup java -jar -Xms128M -Xmx256M -XX:PermSize=128M -XX:MaxPermSize=256M process-activiti-0.0.1-SNAPSHOT.jar > activiti.log 2>&1 &

简介
在实验环境或生产环境中,往往一台linux服务器需要添加启动n个项目,但是项目启动占用的jvm内存默认值基本上都是很大的,800m到2G都有,这样很容易将服务器的内存吃垮,从而导致系统强制oom(内存泄露),不留任何情面;
所以,我们在部署项目的时候需要进行jvm参数的调优设置,保证内存使用的稳定性;
1. 首先执行命令:free -h,查询当前的内存占用情况,从下图可看出,内存已被撑爆;

2.  开始进行优化,执行命令:top,查看各个应用的内存占用情况,选取内存占用过高的pid进程;

 3. 然后获取pid号5252,根据pid查询对应的进程以及项目路径,执行命令:ps -aux |grep -v grep|grep 5252

 4. 定位到项目跟路径之后,开始设置项目启动jvm内存占用,不同项目可分配不同的内存;

  • 如果是springboot项目jar启动,则在启动的时候指定jvm的内存分配:
  • nohup java -jar -Xms128M -Xmx256M -XX:PermSize=128M -XX:MaxPermSize=256M process-activiti-0.0.1-SNAPSHOT.jar > activiti.log 2>&1 &
  • 如果是tomcat项目启动,则在bin目录下,执行命令:vim catalina.sh,然后在顶部加上:
  • JAVA_OPTS="-Xms128m -Xmx256m"

5. 重新启动项目之后,执行命令查询修改情况:jps -v

 6. 将所有高消耗的项目都修改重启之后,重新查看内存占用情况:free -h,如下图,已经腾出了近4G空间,jvm参数调优设置完成;

Logo

华为云1024程序员节送福利,参与活动赢单人4000元礼包,更有热门技术干货免费学习

更多推荐