阅读 38

java 中STW现象解决

先自己弄个问题

产生这个STW问题有 dump线程 死锁检查 堆dupm

/**产生stw其它几个因素:
 *   	dump线程
 *      死锁检查
 *      堆dupm
 *   垃圾回收算法:为让stw时间较长,增大年老代空间和选用serial old垃圾算法进行回收老年代
 *   			 
 *  
 *  jvm垃圾回收参数:-Xms512m -Xmx512m -Xmn4m -XX:+PrintGCDetails -XX:+UseSerialGC 
 *   </code>
 * @author zhanghua
 * 
 */
public class GenerateSTW {
	/**
	 * 通过集合引用对象,保证对象不被gc回收
	 */
	private List<byte[]> content=new ArrayList<byte[]>();
	public static void main(String[] args) {
		GenerateSTW stw=new GenerateSTW();
		stw.start();
	}

	private void start() {
		while(true){
			try {
				content.add(new byte[1024]);
			} catch (OutOfMemoryError e) {
				//在不可以分配的时候,进行清理部分空间,继续运行,这样会很快产生下一次垃圾回收
				for(int i=0;i<1024;i++){
					content.remove(i);
				}
				
			}
			
		}
	}

}

复制代码

是否有方法尽可能减少一次STW停顿时间?由此带来的弊端是什么?

答:减少一次STW停顿时间,我这里从三个方面回答,

1、个是垃圾算法选择

垃圾算法选择:现在都是多核cpu,可以采用并行和并发收集器,如果是响应时间优化的系统应用 ,则jdk6版本一般

选择的垃圾回收算法是:XX:+UseConcMarkSweepGC,即cms收集器,这个收集器垃圾回收时间短,但是垃圾回收总时间变长,使的降低吞 吐量,算法使用的是标记-清除,并发收集器不对内存空间进行压缩,整理,所以运行一段时间以后会产生"碎片",使得运行效率降低. CMSFullGCsBeforeCompaction此值设置运行多少次GC以后对内存空间进行压缩

2、一个是程序使用堆设置

程序使用堆设置:应该根据程序运行情况,通过Jvm垃圾回收分析,设置一个比较合适的堆大小,不能一意味的将堆设置过大,导致 程序回收很大一块空间,所以会导致stw时间较长,

3、无用对象尽早释放

无用对象尽早释放:使用的对象,如果没有用,尽早设置null,尽量在年轻代将对象进行回收掉,可以减少full gc停顿时长

关注下面的标签,发现更多相似文章
评论