`

性能调优 - 第三仗

阅读更多

经过前两次的性能优化之后,系统性能已经得到了很大提升,不存在登陆页面打不开的情况。

又经过一段时间的观察,发现系统有如下两个比较明显的问题:

1、登进系统之后点菜单,能明显感觉到系统有停顿

2、个别实例偶尔会宕掉

 

当时拿到这两个问题的时候,比较没有头绪,尤其是第一个问题,不知道从哪里下手。所以,挑了一个感觉比较好定位的问题2入手。

 

查看了实例的日志文件,发现已经有一段时间没有往文件里面写入日志了。说明这个应用已经停止服务了。既然停止服务,当时推测认为要么实例进程已经停掉了,要么虚拟机进程宕掉了,即内存溢出了。

 

用ps -exf|grep 服务关键字 命令查了一下服务进程,发现进程还在,基本排除第一种推测。

 

然后针对第二种推测,使用jstat -gcutil pid 1000 1000 观测了一段时间的垃圾回收情况,发现老年代的内存使用率一直是100%。

看到这种结果,已经可以明确确定是虚拟机内存溢出了。这也就证明第二种推测是正确的。

 

正在得意的时候,发现另一个惊喜:那就是fullGC的次数比minorGC的次数要多的多,有经验的同学都知道,老年代的fullGC策略执行的时候,jvm是停止用户线程的响应的。说白了就是fullGC的时候,jvm是不会处理请求的。而这里的fullGC几乎占用了全部GC的时间,说明在很大的一段时间内,jvm不提供对外服务。

 

看来病灶我们已经找到,接下里就要对症下药了。

 

从jstat监控结果来看,每进行一次minorGC,就会进行一次fullGC,也即是说新生代的内存空间小。因为新生代分为三个区域:eden区,程序new出来的对象都是放到这里的。

s1区,当minorGC的时候,eden区会将没有被回收的数据放到s1

s2区,当minorGC的时候,s1区会将没有被回收的数据放到s2

 

由于我们没有设置新生代的大小,也没有设置幸存区和eden区的比率,所以新生代的内存空间很小。这样每次minorGC的时候,由于没有足够的内存来存储存活下来的对象,那么只能把数据对象放到老年代。这样相当于程序new出来的对象经新生代转调一下直接进入了老年代,那么照此发展下去,老年代很快就会内存不足,没有足够空间容纳对象的时候,就会触发fullGC。

 

所以我们要调大新生代的空间,这样保证有足够空间来存放程序new出来的对象,并保证在经过多次minorGC之后,只有很好一部分对象能存活下来。这也正是我们系统的特点,会生成很多生命周期较短的对象,它们可能在一次minorGC不会被回收,但是在多个minorGC之后一定会被回收。所以我们要新生代,有足够的空间让对象自生自灭,不要存活到老年代。

 

调整新生代的jvm参数

-Xmn1024m

-XX:survivorRatio=2

 

相关参数的含义,不在这里解释,不明白的大家百度一下。

 

经过这三仗打下来,我们的系统运行基本稳定,没有再出现性能问题。

 

只要我们有问题终究会被定位并且解决的信念,那么我们战无不胜,以此和大家共勉,谢谢~~

 

分享到:
评论

相关推荐

    从零开始学调优-Java 全技术栈 性能调优.txt

    视频教程

    《数据库性能调优--原理与技术》

    《数据库性能调优--原理与技术》是一本深入探讨数据库性能优化的专业书籍,旨在帮助读者理解和掌握提升数据库系统效率的关键技术和方法。通过学习本书,读者能够有效地解决在实际工作中遇到的数据库性能问题,提高...

    数据库性能调优--原理与技术2.pdf

    ### 数据库性能调优——原理与技术(针对Oracle) #### 一、数据库性能调优概述 在当前数据密集型的应用环境中,数据库系统的性能直接影响着企业的业务效率和用户体验。《数据库性能调优——原理与技术2》这本书...

    性能调优-(2)Explain详解与索引优化最佳实践

    性能调优-(2)Explain详解与索引优化最佳实践

    数据库性能调优--原理与技术

    ### 数据库性能调优——原理与技术 #### 一、基础知识与重要概念 **1.1 数据库性能调优概述** 数据库性能调优是确保数据库系统高效稳定运行的关键环节之一。它不仅涉及到对数据库本身的调整,还包括对底层硬件、...

    数据库性能调优--原理与技术.rar

    数据库性能调优是IT领域中的一个关键话题,尤其是在大数据时代,高效、稳定的数据处理能力直接影响着业务的运行效率。这个压缩包文件“数据库性能调优--原理与技术”很可能包含了关于如何优化数据库性能的深入讲解和...

    数据库性能调优--原理与技术1.pdf

    #### 三、Oracle数据库性能调优概述 Oracle数据库因其强大的功能和广泛的应用场景而备受青睐。然而,随着数据量的不断增加和技术需求的日益复杂,对Oracle数据库进行性能调优显得尤为重要。 ##### 3.1 诊断工具 -...

    JVM性能调优-JVM内存整理及GC回收

    《JVM性能调优-JVM内存整理及GC回收》是一份深入探讨Java虚拟机(JVM)优化的重要学习资料,特别适合对JAVA编程有经验的开发者。这份文档详细阐述了JVM性能调优的关键概念,包括JVM内存模型、垃圾回收(Garbage ...

    数据库性能调优-原理与技术

    ### 数据库性能调优——原理与技术 在当今数字化时代,数据成为了企业最宝贵的资产之一。随着业务量的增长和技术的发展,数据库系统面临着越来越大的压力。为了确保数据处理的速度和效率,进行有效的数据库性能调优...

    AIX性能调优-pdf

    ### AIX性能调优知识点详解 #### 一、AIX简介及内部结构 AIX(Advanced Interactive Executive)是由IBM开发的一款基于Unix的操作系统,专为IBM的Power Systems服务器设计。AIX以其高度的安全性、稳定性和灵活性而...

    oracle性能调优--解决CPU高度消耗(100%)

    Oracle 性能调优 -- 解决 CPU 高度消耗 (100%) Oracle 性能调优是数据库管理和维护中非常重要的一部分。当数据库出现性能问题时,需要快速定位和解决问题,否则将影响业务的正常运作。在这里,我们将讨论如何解决 ...

    Java程序性能调优-视频教程

    学习Java程序性能调优视频教程后,有助于您的专业技术大度上升。解决工作诸多问题,快来吧。

    AIX性能调优-牛新庄

    标题“AIX性能调优-牛新庄”指向了专门针对AIX操作系统进行性能调优的技术内容,AIX是IBM开发的一种UNIX操作系统,主要应用于其Power Systems服务器。性能调优是系统管理中的一项重要任务,它旨在提高系统的响应速度...

    大型数据库应用的性能调优-案例学习

    ### 大型数据库应用的性能调优-案例学习 #### 引言 本文档通过一个具体的案例——PeopleSoft系统的性能优化,深入探讨了如何确保关键业务应用在大型数据库环境下的高性能运行。虽然本案例主要针对的是PeopleSoft与...

    通向架构师的道路(第二十四天)之Oracle性能调优-朝拜先知之旅.docx

    Oracle性能调优-朝拜先知之旅 本文主要介绍了在 Linux 环境下安装 Oracle 10g 的方法,并对 Oracle 性能调优进行了详细的说明。下面是本文的知识点总结: 一、Oracle 基本概念 * Oracle 是一种关系型数据库管理...

    11_性能调优-AWR报表解读1

    **性能调优-AWR报表解读** Oracle 10g版本引入了一个重要的性能监控工具——Automatic Workload Repository(AWR),它是数据库管理员进行性能优化的重要参考。AWR通过定期捕获数据库的状态快照(snapshot),然后...

    JVM性能调优-JVM内存整理及GC回收.docx

    JVM性能调优-JVM内存整理及GC回收 JVM(Java Virtual Machine)性能调优是 Java 开发者需要掌握的重要技能之一。 JVM 的性能调优主要涉及到 JVM 内存整理、垃圾回收(GC)机制等方面。 Java 中的值传递和引用传递...

    Java性能调优--关于垃圾回收机制的分析和指导

    Java性能调优,特别是关于垃圾回收机制的分析和指导,是优化Java应用程序的关键环节。Java的垃圾回收(Garbage Collection, GC)是自动管理内存的一种机制,它负责识别并清理那些不再使用的对象,以释放内存资源。...

Global site tag (gtag.js) - Google Analytics