[性能调优] out of memory :Heap space

题目其实取大了……

背景:线上环境java服务报错,异常如题out of memory :Heap space
环境:32位 jdk 1.8

以下所说的解决方案,都是尝试过的一些手段,我对jvm只是知道一些皮毛,所以无法深入分析,各位看官且当病急乱投医时的一个参考吧。

(1) 定位到抛异常的代码段,把可疑对象用完后显示置为null,想着这样能尽快让该对象被GC回收
(2) 增加堆内存设置,-xms和-xmx
(3) 这个就是今天要提到的了。。。JIT server模式设置

JIT(Just In Time,即时编译技术)是指当jvm运行程序时,会把翻译过的机器码保存起来,以备下次使用。
它有两种模式,server mode和client mode
server mode 下,java程序启动较慢,程序运行过程中,jvm会做很多性能提升的操作,适合性能较好的服务器。新生代gc方式是并行,老生代gc方式是并发。
client mode下,java程序启动较快,适合轻量级客户端,新生代,老生代的gc方式都是串行。

设置方式

64位的jdk只能使用server mode,32位jdk默认是client mode,如果要换成server mode,需要做以下步骤:

  1. 打开C:\Program Files (x86)\Java\jre1.8.0_121\lib\i386\jvm.cfg文件,将-server KNOWN放于-client KNOWN之上,如下


    jvmcfg.png
  2. 把jdk下面的jre里的server文件夹拷贝到jre的bin目录下


    拷贝server文件夹.png

此次通过方案3,莫名解决了堆内存溢出问题。。。程序员总是莫名解决各种bug,哈哈

等我回头研究下jvm,再补充补充o( ̄︶ ̄)o

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 参数设置 在Java虚拟机的参数中,有3种表示方法用“ps -ef |grep "java"命令,可以得到当前Ja...
    九问阅读 9,190评论 2 52
  • jvm原理 Java虚拟机是整个java平台的基石,是java技术实现硬件无关和操作系统无关的关键环节,是java...
    AI乔治阅读 17,310评论 21 486
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 135,026评论 19 139
  • 掐指一算,从大学毕业到工作,已经过了近8个月的时间。作为一个运维的人员,总觉得自己不专业。换句话说吧,如果现在公司...
    AdH阅读 441评论 0 3
  • 还是喜欢这台词 爱我所爱 行我所行 听从内心 无问西东 是的 要做自己喜欢的事 做适合自己的事 做自己能做的事 面...
    静轩茶香阅读 216评论 0 5