JVM参数调优及JAVA工具使用.ppt_第1页
JVM参数调优及JAVA工具使用.ppt_第2页
JVM参数调优及JAVA工具使用.ppt_第3页
JVM参数调优及JAVA工具使用.ppt_第4页
JVM参数调优及JAVA工具使用.ppt_第5页
已阅读5页,还剩25页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、是一个自动内存管理程序。主要职责是分配内存,以确保引用的对象始终在内存中。从内存中释放未应用的对象将自动计算对象的引用情况。只要对象不再被引用,相应的内存就会被回收。此外,垃圾收集对于避免内存碎片非常重要。原因与windows磁盘排序相同,集成了所有正在使用的内存块,从而确保有足够的空间来存储大型对象。理想的GC,即恢复的恢复,不应该被恢复,永远不要恢复GC,并且当GC正在运行时,它不能导致应用程序停止。限制内存碎片。回收对象后,使用的内存将被回收。如果不处理,内存中会出现大量内存碎片,这可能会导致内存不足,因为没有足够的连续空间分配给一些大型对象。消除内存碎片的方法之一是“内存压缩”。可扩展

2、性、内存分配和恢复不能成为应用程序的瓶颈,不能成为垃圾收集的性能评估标准,不能成为垃圾收集始终未使用的吞吐量比例。(焦点)暂停时间应用程序在垃圾收集期间暂停执行的时间。(强调)GC的成本:花费在GC上的总时间的比例。将垃圾收集的频率与应用程序的执行频率进行比较,得到垃圾收集的执行频率。支持垃圾收集操作所需的内存大小,如堆的大小。被丢弃的对象和被回收的内存之间的时间差。32位操作系统有4G的限制,但64位操作系统没有。JVM最初分配的内存由-Xms指定,它是物理内存的1/64,但默认情况下小于1G。JVM分配的最大内存由-Xmx指定,它是物理内存的1/4,但默认情况下小于1G。-xx3360 m

3、inheapfreeratio=40-xx3360 maxheapfreeratio=70服务器通常将-Xms和-Xmx设置为相等,以避免在每次垃圾收集后调整堆的大小。收集算法(1),复制:将堆分成两个相同的空间,从线程本地对象开始,静态对象)开始访问每个关联的活动对象,将空间A中的所有活动对象复制到空间B,然后一次回收整个空间A。优点:遍历对象成本低,但缺点:只遍历活动对象成本高,需要更多内存。标记扫描:收集器首先从根访问所有活动对象,并将它们标记为活动对象。然后再次遍历整个内存区域,并回收所有未标记为活动的对象。优点:无需复制。缺点:穿越整个空间的成本很高。暂停时间随空间大小线性增加,完成

4、后堆中有许多碎片。这个算法有一个阶段,标记(标记)、扫描(扫描)、压缩(压缩)。结合前两者的实践和优点,首先标记活动对象,然后将其合并到更大的内存块中。收集算法(3)根据对象的生命周期分为三代:年轻(年轻一代,新一代)年老(老一代)永久(永恒一代)优点:根据不同代的特点采用不同的收集算法优点和缺点,堆内存分布图,-Xms1024m -Xmx1024m堆大小-xx3360新大小=256m-xx3360max新大小=256m新生代大小-xx3360max大小=128m-xx3360 max大小=128m不朽新生代物体经过两次进入老年、青年、青年(幼儿)和年轻一代。研究表明,大多数物体都是短暂的,随

5、着出生而死亡。因此,所有的收集者都为年轻一代选择了复制算法。扬分为三个区域,一个伊甸园,所有新的对象将存在,和两个幸存者区域,这是用来实现复制算法。每一次复制都是将伊甸园和第一个生存者的生物复制到第二个街区,然后清空伊甸园和第一个生存者。由于新生代的空间通常很小,可能有大量对象不再被引用,因此新生代的气相色谱执行频率和速度都很高。老一代,老一代,老一代。如果年轻一代能在几次收藏中幸存下来,他们将进入老一代。老一代使用标签排序算法。因为老一代的对象不容易死亡,所以使用复制算法重复复制对象是不经济的,所以我们必须使用标记清洗算法,但是标记清洗算法实际上并不容易,并且每次我们必须遍历该区域中的所有对

6、象-XB : maxtenaring threshold=2 perm(永久的),永恒的一代。例如类和方法对象及其描述对象。串行收集器,标记-扫描-压缩,仅使用一个cpu,回收时,应用程序将暂停-XX: UseSerialGC,并行收集器,新生代并行收集器,停止-世界和应对收集器,但多线程老一代和永恒一代标记-扫描-压缩,-XX : UseParallelGc-XX 3360 UseParallelDGc(并行压缩回收器)-XX : parallelGcthreads=-XX 3360 maxgcpauseMaris=-XX : gctimeratio=,-XX : UseConcMarksw

7、epgc-XX : UseParNewGc-XX : CmParallelreMarkenabled-XX : CmPartitioningCCupincreaction=60-XX : CmFullGsbeForeco compaction=5-XX : UseCmCompactfullCollection,吞吐量优先。Java-server-Xlogg c : GC . log-XMx 1024m-XMs 1024m-Xx : newSiZe=256m-Xx : MaxNewSiZe=256m-Xx : PermSiZe=128m-Xx : MaxPermSiZe=128m-Xss 1 2

8、8k-Xx : use parallelgc-Xx : use parallel dgc,短暂停是首选。Java-server-Xlogg c : GC . log-XMx 1024m-XMs 1024m-Xx : newSize=256m-Xx : max newSize=256m-Xx : PermSize=128m-Xx : max PermSize=128m-Xss 12 8k-Xx : useConcMarksweePgc-Xx : parallelgCthreads=8-Xx 3: useParNewgc-Xx 333333:它可用于监控虚拟机内存及其内存中各种堆和非堆的大小。js

9、tat-classpid3360用于显示加载的类的数量和占用的空间。jstat-编译器pid:显示实时编译的虚拟机数量等信息。Jstat -gc pid:可以显示gc信息,检查gc时间和时间。最后五项是年轻gc的数量、年轻gc的时间、完整gc的数量、完整gc的时间和gc的总时间。Jstat -gccapacity:可以显示虚拟机内存中三代(年轻、年老、彼尔姆)对象的使用和占用大小。例如,PGCMN显示perm的最小内存使用量,PGCMX显示perm的最大内存使用量,PGC是新生成的perm内存使用量,而PC是以前的perm内存使用量。其他人可以根据这个类比,OC是在旧的纯粹的职业。jstat-

10、gcnew PID :新对象的信息。jstat-gcnew capacity PID :新对象及其占用的信息。jstat -gcold pid:old对象的信息。jstat-gcoldcapacity PID :旧对象及其占用的信息。jstat-gcpercapacity PID : perm对象的信息及其占用情况。当前虚拟机执行的信息。,jmap,显示内存使用的相关信息java进程jmap pid打印内存使用的概要信息JMAP堆pid java堆信息JMAP-hist : live统计对象计数,Live表示当JMAP-组织id mem.txt用于打印关于有多少对象占用多少内存的简单信息时,一

11、般重定向文件jmap-dump3360format=b,file=mem.dat pid将内存使用的详细信息输出到mem.dat文件。使用jhat命令,您可以参考jhat -port 7000 mem.dat,然后使用:http:/10 . 10 . 92 . 11933607000/查看类相关信息,JINFO,它可以输出和修改运行参数JINFO-标志pid打印名称值JINFO-标志| -pid取消或设置属性JINFO-标志=pid设置属性值JINFO-标志pid输出所有属性值jinfo -sysprops输出JAVA属性jinfo pid输出所有,jconsole是一个图形用户界面并且可以监

12、视远程VM服务器配置:mkdir $ Java _ home/jconsole _ pwdcp $ Java _ home/JRE/lib/management/JMX remote . password . template $ Java _ home/jconsole/JMX remote。密码-chmod 600 $ Java _ home/jconsole/JMxRemote。密码vi JMXRemote。密码删除#monitorRole RED前的注释,并将RED修改为您要设置的密码。(出于安全原因,只有具有只读权限的用户才能打开。在$JAVA_ARGS中添加三个参数:JAVA _

13、args=$ JAVA _ args-DCOM . sun . management . JMX remote . port=1010-DCOM . sun . management . JMX remote . password . file=/usr/local/JDK/jconsole/Execute hostname-I如果它显示,JMX remote . password-DCOM . sun . management . JMX remote . SSL=false。/etc/hosts文本vi /etc/hosts需要修改如下:# 127 . 0 . 0 . 1

14、 localhost localhost . local domain localhost,jstack,Jstack -如果一个java程序崩溃生成一个核心文件,Jstack工具可以用来获取java堆栈和核心文件的本机堆栈的信息,这样您就可以很容易地知道java程序是如何崩溃的,以及程序在哪里出错。Jstack工具也可以附加到正在运行的java程序上,参见java栈和当时运行的Java程序的本机栈的信息。jstack -l连接正在运行的进程jstack -F -m -l连接挂起的进程jstack -m -l连接核心文件jstack -m -l server_id连接远程服务器。请参考参考资料。用Java 5.0虚拟机官方指南调优垃圾收集。

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论