jvm调优经验分享
当Java程序申请内存,超出VM可分配内纯的时候,VM首先可能会GC,假设GC完还是不够,或者申请的直接超够VM可能有的,就会抛出内 存溢出异常。从VM规范中我们能够得到,一下几种异常。
java.lang.StackOverflowError:(非常少)
java.lang.OutOfMemoryError:heap space(比較常见)
java.lang.OutOfMemoryError: PermGen space (常常出现)
java.lang.OutOfMemoryError: GC overhead limit exceeded(某项操作使用大量内存时发生)
下面分别解释一下,从最常见的開始:
java.lang.OutOfMemoryError: PermGen space 这个异常比較常见,是说JVM里的Perm内 存区的异常溢出,因为JVM在默认的情况下,Perm默觉得64M,而非常多程序须要大量的Perm区内 存,尤其使用到像Spring等框架的时候,因为须要使用到动态生成类,而这些类不能被GC自己主动释放,所以导致OutOfMemoryError:
PermGen space异常。解决方法非常easy,增大JVM的 -XX:MaxPermSize 启动參数,就能够解决问题,如过使用的是默认变量一般是64M[5.0 and newer: 64 bit VMs are scaled 30% larger; 1.4 amd64: 96m; 1.3.1 -client: 32m.],改成128M就能够了,-XX:MaxPermSize=128m。假设已经是128m(Eclipse已经是128m了),就改成 256m。我一般在server上为安全起见,改成256m。
java.lang.OutOfMemoryError:heap space或其他OutOfMemoryError,这个异常实际上跟上面的异常是一个异常,但解决方法不同,所以分开来写。上面那个异常是由于JVM的perm区内 存区分少了引起的(JVM的内 存区分为 young,old,perm三种)。而这个异常是由于JVM堆内
存或者说整体分少了。解决方法是更改 -Xms -Xmx 启动參数,一般是扩大1倍。xms是管理启动时最小内 存量的,xmx是管里JVM最大的内 存量的。
注:OutOfMemoryError可能有非常多种原因,依据JVM Specification, 可能有一下几种情况,我先简单列出。stack:stack分区不能动态扩展,或不足以生成新的线程。Heap:须要很多其它的内 存,而不能获得。Method Area :假设不能满足分配需求。runtime constant pool(从Method Area分配内 存)不足以创建class or interface。native method stacks不可以动态扩展,或生成新的本地线程。
java.lang.OutOfMemoryError: GC overhead limit exceeded,这个是JDK6新添的错误类型。这个hotspot VM1.6定义的一个策略,是一种保护机制,通过计算GC时间来预測是否须要OOM了,提前抛出异常,防止OOM的发生,官方的定义是:并行/并发回收器在GC回收时间过长会抛出OutOfMemoryError(过长的定义是超过98%的时间用来GC并回收了不到2%的堆内存,用来避免内存过小造成应用不能正常工作。我在JSP导大Excel的时候碰到过。终于解决方式是,关闭该功能,使用——
-XX:-UseGCOverheadLimit,预測OOM有啥用呢?尽管可能不能终于解救你的应用,可是能够在挂掉前做最后的挣扎,比方数据保存和保存现场(Heap Dump),当然这个策略会带来比方载入某一个大内存时频繁OOM。增加生产环境遇到这个问题,在不知道原因的情况下不要简单规避这个问题,能够通过-verbose:gc -XX:+PrintGCDetails看一下究竟是什么原因造成的异常。通常原因都是由于年老代(old区)占用过多导致频繁FullGC,终于导致GC overhead limit exceed。假设gc
log不够能够借助JProfile等工具查看内存占用,old区是否有内存泄漏。。分析内存泄漏有一个方法 -XX:HeapDumpOnOutOfMemoryError, 这样OOM时会自己主动做Heap Dump,能够拿MAT来排查了。另外留意新生代(young区),假设有过多短暂对象分配,可能也会导致这个异常。
最后说说java.lang.StackOverflowError,老实说这个异常我也没碰见过,但JVM Specification就提一下,规范上说有一下几种境况可能抛出这个异常,一个是Stacks里的线程超过同意的时候,还有一个是当native method要求更大的内
存,而超过native method同意的内 存的时候。依据SUN的文档,提高-XX:ThreadStackSize=512的值。
总的来说调优JVM的内 存,组要目的就是在使用内 存尽可能小的,使程序执行正常,不抛出内 纯溢出的bug。并且要调好最小内 存,最大内 存的比,避免GC时浪费太多时间,尤其是要尽量避免FULL GC。
补充:因为JDK1.4新增了nio,而nio的buffer分配内存比較特殊(读写流能够共享内存)。假设有大量数据交互,也可能导致java.lang.OutOfMemoryError。对应的JDK新增了一个特殊的參数:-XX:MaxDirectMemorySize 默认是64M,能够改大些如128M。
-XX:MaxDirectMemorySize=<size>
Specifies the maximum amount of memory in bytes that the Java™ NIO library can allocate for direct memory buffers. The default is 64 megabytes, which corresponds to
-XX:MaxDirectMemorySize=64m . The use of direct memory buffers can minimize the copying cost when doing I/O operations.
jvm调优经验分享的更多相关文章
- MYSQL企业常用架构与调优经验分享
一.选择Percona Server.MariaDB还是MYSQL mysql应用源码:http://www.jinhusns.com/Products/Download/?type=xcj 1.M ...
- MYSQL 企业常用架构与调优经验分享
一.选择Percona Server.MariaDB还是MYSQL mysql应用源码:http://www.jinhusns.com/Products/Download/?type=xcj 1.M ...
- JVM调优之经验
在生产系统中,高吞吐和低延迟一直都是JVM调优的最终目标,但这两者恰恰又是相悖的,鱼和熊掌不可兼得,所以在调优之前要清楚舍谁而取谁.一般计算任务和组件服务会偏向高吞吐,而web展示则偏向低延迟才会带来 ...
- 性能调优案例分享:jvm crash的原因 1
性能调优案例分享:jvm crash的原因 poptest是国内唯一一家培养测试开发工程师的培训机构,以学员能胜任自动化测试,性能测试,测试工具开发等工作为目标.如果对课程感兴趣,请大家咨询qq: ...
- 老李分享:JVM调优
老李分享:JVM调优 poptest是国内唯一一家培养测试开发工程师的培训机构,以学员能胜任自动化测试,性能测试,测试工具开发等工作为目标.如果对课程感兴趣,请大家咨询qq:908821478,咨 ...
- jvm 性能调优 经验总结---转
最近因项目存在内存泄漏,故进行大规模的JVM性能调优 , 现把经验做一记录. 一.JVM内存模型及垃圾收集算法 1.根据Java虚拟机规范,JVM将内存划分为: New(年轻代) Tenured(年老 ...
- JVM性能调优经验总结
本文转载自JVM性能调优经验总结 说明 调优是一个循序渐进的过程,必然需要经历多次迭代,最终才能换取一个较好的折中方案. 在JVM调优这个领域,没有任何一种调优方案是适用于所有应用场景的,同时,切勿极 ...
- JVM调优(二)经验参数设置
调优设置具体解析 堆大小设置 JVM 中最大堆大小有三方面限制:相关操作系统的数据模型(32-bt还是64-bit)限制:系统的可用虚拟内存限制:系统的可用物理内存限制.32位系统下,一般限制在1.5 ...
- JVM调优的几种策略(转)
JVM参数调优是一个很头痛的问题,可能和应用有关系,别人说可以的对自己不一定管用.下面是本人一些JVM调优的实践经验,希望对读者能有帮助,环境LinuxAS4,resin2.1.17,JDK6.0,2 ...
随机推荐
- 浅谈PPM (Project Portfolio Management) - 1
前言: 本文以纯理论性的PPM解说为主,不会涉及到具体怎样实施,我会在以后介绍具体的PPM实施方案介绍. PPM,可能非常多人并不清楚甚至可能没听说过,这是一个近些年才流行起来的概念,是Project ...
- Opera浏览器测试移动端网站和模拟手机浏览器的方法
链接地址:http://www.neirong.org/post-256.html?utm_source=tuicool Chrome浏览器请看:Chrome浏览器测试移动端网站和模拟手机浏览器的方法 ...
- Net MVC轻量级分页控件
JPager.Net MVC超好用轻量级分页控件 JPager.Net MVC好用的轻量级分页控件,好用到你无法想象,轻量到你无法想象. JPager.Net MVC好用的轻量级分页控件,实现 ...
- NET 2016
.NET 2016 阅读目录 初识 .NET 2016 使用 .NET Framework 4.6 编译应用程序 使用 .NET Core CLI 编译应用程序 小结 厚积薄发这个词是高三英语老师 ...
- WCF技术剖析之六:为什么在基于ASP.NET应用寄宿(Hosting)下配置的BaseAddress无效
原文:WCF技术剖析之六:为什么在基于ASP.NET应用寄宿(Hosting)下配置的BaseAddress无效 本篇文章来源于几天前一个朋友向我咨询的问题.问题是这样的,他说他采用ASP.NET应用 ...
- openfire数据库中文乱码问题
1.首先数据库的编码设置为UTF-8 2.项目的编码也要设置为UTF-8 假设数据保存到数据库的时候还有乱码 就要改动openfire配置文件 在openfire主文件夹\conf\openfire ...
- Android手势识别 Camera 预览界面上显示文字 布局注意事项(merge布局)
通常在Surfaceview作为预览视频帧的载体,有时需在上面显示提示文字.曾经我弄的都好好的.今天忽然发现叠加的TextView不管咋弄都出不来文字了,跟Surfaceview一起放在FrameLa ...
- 矩形、占位符组件——axure线框图部件库介绍
矩形组件和占位符没有太多的区别,这里我们主要讲解矩形组件的操作和使用,占位符的操作各位可以按照矩形的操作方法进行练习一下. 矩形组件是一个矩形,它可以用来做很多的工作,比如页面上需要一块蓝色的背景,就 ...
- Winfrom设置DataGridView单元格获得焦点(DataGridView - CurrentCell)
设置DataGridView单元格获得焦点 this.dgv_prescription.BeginEdit(true);
- 基于visual Studio2013解决C语言竞赛题之1051数的顺序
题目 解决代码及点评 /* 功能:自然数N一般写成如下形式: N=d[k]d[k-1]d[1] (d[1]-d[k] 均是十进制数字) 如果d[i+1]>d[i] (i=k-1 ...