server jvm和client
jvm对字节码优化的策略不同:
Ø Client主要优化对用户交互的响应速度
Ø Server主要优化后台运行的代码。
使用server模式可以提高性能,启动比client模式慢,长期运行则比client模式快。当该参数不指定时,虚拟机启动检测主机是否为服务器,如果是,则以server模式启动,否则以client模式启动,J2SE5.0检测的根据是至少2个CPU和最低2GB内存。
20.7.3 堆大小设置
JVM中最大堆大小有三方面限制:相关操作系统的数据模型(32-bt还是64-bit)限制;系统的可用虚拟内存限制;系统的可用物理内存限制。在32位系统下,一般限制在1.5G~2G;64为操作系统对内存无限制。
常用的典型设置如下:
Ø java -Xmx3550m -Xms3550m -Xmn2g -Xss128k
-Xmx3550m:设置JVM最大可用内存为3550M。
-Xms3550m:设置JVM初始化内存为3550m。此值可以设置与-Xmx相同,以避免每次垃圾回收完成后JVM重新分配内存。
-Xmn2g:设置年轻代大小为2G。整个堆大小=年轻代大小 + 年老代大小 + 持久代大小。持久代一般固定大小为64m,所以增大年轻代后,将会减小年老代大小。此值对系统性能影响较大,Sun官方推荐配置为整个堆的3/8。基于对对象生命周期分析后得出的垃圾回收算法。把对象分为年青代、年老代、持久代,对不同生命周期的对象使用不同的算法(上述方式中的一个)进行回收。现在的垃圾回收器(从J2SE1.2开始)都是使用此算法的。
-Xss128k:设置每个线程的堆栈大小。从JDK5.0开始,每个线程堆栈大小为1M,以前每个线程堆栈大小为256K。可根据具体应用调整线程所需内存大小。在相同物理内存下,减小这个值能生成更多的线程。但是操作系统对一个进程内的线程数还是有限制的,不能无限生成,通常的值在3000~5000左右。
20.7.3 回收器选择
在JVM中给了三种回收器的选择:串行收集器、并行收集器、并发收集器,但是串行收集器只适用于小数据量的情况,所以这里的选择主要针对并行收集器和并发收集器。默认情况下,在JDK5.0以前都是使用串行收集器,如果想使用其他收集器需要在启动时加入相应参数。从JDK5.0以后,JVM会根据当前系统配置进行判断。
并行收集器主要以到达一定的吞吐量为目标,适用于科学技术和后台处理等。 典型配置如下:
Ø java –Xmx2800m -Xms800m -Xmn2g -Xss128k
-XX:+UseParallelGC -XX:ParallelGCThreads=20 -XX:+UseParallelOldGC
-XX:+UseParallelGC:选择垃圾收集器为并行收集器。此配置仅对年轻代有效。即上述配置下,年轻代使用并发收集,而年老代仍旧使用串行收集。
-XX:ParallelGCThreads=20:配置并行收集器的线程数,即同时多少个线程一起进行垃圾回收。此值最好配置与处理器数目相等。
-XX:+UseParallelOldGC:配置年老代垃圾收集方式为并行收集。JDK6.0支持对年老代并行收集。
并发收集器主要是保证系统的响应时间,减少垃圾收集时的停顿时间。适用于应用服务器、电信领域等。典型配置如下:
Ø java -Xmx3550m -Xms3550m -Xmn2g -Xss128k
-XX:ParallelGCThreads=20 -XX:+UseConcMarkSweepGC -XX:+UseParNewGC
-XX:+UseConcMarkSweepGC:设置年老代为并发收集。
-XX:+UseParNewGC:设置年轻代为并行收集。可与CMS收集同时使用。从JDK5.0开始JVM会根据系统配置自行设置,所以无需再设置此值。
20.7.4 年轻代大小选择
响应时间优先的应用:年轻代尽可能设大,直到接近系统的最低响应时间限制(根据实际情况选择)。在此种情况下,年轻代收集发生的频率也是最小的。同时,减少到达年老代的对象。
吞吐量优先的应用:年轻代尽可能的设置大,可能到达Gbit的程度。因为对响应时间没有要求,垃圾收集可以并行进行,一般适合8CPU以上的应用。
20.7.5 年老代大小选择
响应时间优先的应用:年老代使用并发收集器,所以其大小需要小心设置,一般要考虑并发会话率和会话持续时间等一些参数。如果堆设置小了,可以会造成内存碎片、高回收频率以及应用暂停而使用传统的标记清除方式;如果堆大了,则需要较长的收集时间。最优化的方案,一般需要参考以下数据获得:
Ø 并发垃圾收集信息
Ø 持久代并发收集次数
Ø 传统GC信息
Ø 花在年轻代和年老代回收上的时间比例
Ø 减少年轻代和年老代花费的时间,一般会提高应用的效率
吞吐量优先的应用:一般吞吐量优先的应用都有一个很大的年轻代和一个较小的年老代。原因是,这样可以尽可能回收掉大部分短期对象,减少中期的对象,而年老代尽存放长期存活对象。
20.7.6 较小堆引起的碎片分析
因为年老代的并发收集器使用标记、清除算法,所以不会对堆进行压缩。当收集器回收时,它会把相邻的空间进行合并,这样可以分配给较大的对象。但是,当堆空间较小时,运行一段时间以后,就会出现“碎片”,如果并发收集器找不到足够的空间,那么并发收集器将会停止,然后使用传统的标记、清除方式进行回收。如果出现“碎片”,可能需要进行如下配置:
-XX:+UseCMSCompactAtFullCollection:使用并发收集器时,开启对年老代的压缩。
-XX:CMSFullGCsBeforeCompaction=0:上面配置开启的情况下,这里设置多少次Full
GC后,对年老代进行压缩
相关推荐
标题提到的“深入理解JVM虚拟机”,意味着要对JVM的内部机制进行深入的研究和理解。其核心知识点涵盖了如下几个方面: 1. JVM架构组成:JVM主要由类加载器(Class Loader)、运行时数据区(Runtime Data Area)、...
《JVM虚拟机深度讲解》这本书是JAVA开发者深入理解JVM的重要参考资料,它全面而详尽地探讨了Java虚拟机的工作原理与优化技巧。通过阅读本书,开发者可以大幅提升对JVM的理解,从而在编程实践中更好地驾驭这个强大的...
JVM虚拟机面试知识点解析 本文主要针对JVM虚拟机面试中的常见问题进行解析,涵盖了JVM的基础...本文对JVM虚拟机的基础知识、结构组成、类加载器的工作原理等方面进行了详细的解析,为软件开发人员提供了详细的知识点。
JVM虚拟机规范是Java程序运行的基础,它定义了JVM如何执行字节码以及内存管理的规则。其主要内容包括: 1. **类加载子系统**:描述了如何加载、验证、准备、解析和初始化类。 2. **运行时数据区**:包括堆、方法区...
《深入理解JVM虚拟机:从基础到实践》 JVM(Java Virtual Machine)是Java程序的核心组成部分,它为Java程序提供了跨平台的运行环境。本资料集合包含了多个关于JVM学习的重要主题,旨在帮助读者从基础到深入地掌握...
《实战Java虚拟机——JVM故障诊断与性能优化》内容简介:随着越来越多的第三方语言(Groovy、Scala、JRuby等)在Java虚拟机上运行...第11章介绍了虚拟机的执行系统和字节码,并给出了通过ASM框架进行字节码注入的案例。
在Java虚拟机(JVM)中,字节码自动加载是一项关键功能,它使得Java程序能够在运行时动态地发现和加载类。字节码是由Java源代码编译而成的二进制格式,它包含了类和接口的信息。了解JVM如何自动加载字节码对于深入...
1. **类加载(Class Loading)**:JVM的类加载器(Class Loader)负责加载字节码文件到内存中。它遵循双亲委派模型,确保类的唯一性,避免重复加载。类加载器首先检查类是否已被加载,如果没有,则递归地加载其父类...
1. JVM 的基本概念:JVM(Java Virtual Machine)是 Java 程序的运行环境,负责将 Java 字节码转换为机器代码并执行。JVM 由类加载器、运行时数据区和执行引擎组成。 2. 设置 JVM虚拟机大小的必要性:Tomcat 无法...
这可能包括对字节码的优化、内存管理策略调整、垃圾回收算法的选择等。 8. **社区支持与文档**: 开源JVM项目通常有活跃的社区支持,开发者可以通过社区获取帮助、报告问题或贡献代码。同时,详细的文档也是评估开源...
JVM通过解释器逐条解释执行字节码,也可以使用JIT编译器将热点代码编译为机器码,提高执行效率。 ### 内存管理 JVM内存分为新生代、老年代和持久代(在某些JVM实现中是元空间)。垃圾收集器通过不同的算法(如...
JVM则是执行Java字节码的平台,存在于JRE中。 JVM的运行时数据区内存模型分为几个关键区域: 1. 程序计数器:每个线程都有自己独立的程序计数器,用于存储下一条即将执行的指令地址,是线程安全的,也是唯一不会抛...
8. **异常处理**:JVM根据字节码中的异常表来处理异常,支持try-catch-finally结构,确保finally块总能得到执行。 9. **模块系统(Module System)**:Java9引入了模块化系统,以帮助开发者更好地组织和管理大型...
首先,我们要了解Java虚拟机(JVM)是Java程序运行的平台,它负责解释和执行Java字节码,为Java应用程序提供了一个跨平台的运行环境。JVM的核心功能包括类加载、字节码验证、内存管理、垃圾收集等。 在JVM性能调优...
以下是在Tomcat环境中优化JVM内存的具体步骤: 1. **环境变量设置**:通过设置`CATALINA_OPTS`环境变量,可以在系统级别全局地调整Tomcat中JVM的内存参数。 2. **编辑catalina.bat**:在Tomcat的bin目录下,直接...
总之,"jvm虚拟机源码学习资料"提供了一个全面了解JVM内部运作的窗口,结合cglib库的实践,将帮助Java开发者提升技术水平,更好地驾驭这个复杂的运行环境,解决实际开发中的各种问题。通过深入学习,不仅可以提升...
总之,Java JVM虚拟机是Java语言运行的基础,它的设计和实现直接影响着Java程序的性能和可移植性。通过深入了解JVM的工作原理,开发者可以更好地优化代码,提高程序运行效率,同时也能充分利用Java的平台无关性优势...
本资源提供的"JVM虚拟机源码(C++)"是针对Java 7版本的HotSpot JVM的源代码,这对于开发者尤其是对JVM原理感兴趣的程序员来说,是一份极其珍贵的学习材料。 HotSpot JVM的源码主要分为以下几个关键部分: 1. **...
JVM通过类加载器将这些字节码加载到内存中,进行验证、准备、解析和初始化等步骤,形成运行时的数据区。 2. **运行时数据区**:包括堆内存、方法区、虚拟机栈、本地方法栈和程序计数器。堆是所有对象实例的存储区域...
Java虚拟机(JVM)是Java程序的运行环境,它负责解释和执行Java字节码文件。字节码文件是用.class扩展名标识的文件,它们是Java源代码经过编译器编译后生成的中间代码形式。这种设计允许Java程序具有跨平台的特性,...