java 开发 jvm_Java开发人员应了解的JVM流行语

java 开发 jvm

本文将与您分享一些JVM“流行语”,它们对于Java开发人员在执行任何JVM性能和垃圾回收调优之前理解和记住非常重要。 本文末尾还提供了一些技巧,包括一些高级性能调优最佳实践。 将来的文章中将探讨有关Oracle HotSpot并发GC收集器(例如CMS和G1)的更多建议。

在继续阅读之前,建议您首先熟悉JVM详细的GC日志。 掌握此JVM数据分析技能至关重要,尤其是与更高级的APM技术结合使用时。

JVM流行语

分配率 分配给YoungGen空间的Java对象,

又名“短暂”对象。

促销率 Java对象从
YoungGen来
OldGen空间。
实时数据 坐在OldGen空间中的Java对象,也称为“长寿”对象。
世界停止收集 垃圾收集,例如Full GC,并导致应用程序线程暂时挂起,直到完成。

首先,JVM GC日志

  • 提供有关Java堆和GC活动的开箱即用的详细信息。
  • 使用GCMV (GC内存可视化工具)之类的工具来评估JVM暂停时间和内存分配率,而不是手动确定世代大小。

JVM_buzzwords_YG

JVM_buzzwords_OG

分配和促销价格

  • 跟踪您的应用程序分配和提升率对于最佳GC性能很重要。
  • 作为JVM人机工程学的一部分,保持GCAdaptiveSizePolicy处于活动状态。 仅在需要时手动调音。

JVM_YG_allocation_rate

JVM_OG_allocation_rate

实时数据计算

  • 完整GC后,您的实时应用程序数据对应于OldGen占用率。
  • 至关重要的是,您的OldGen容量必须足够大,以舒适地保存您的实时数据,并限制主要收集的频率以及对应用程序负载吞吐量的影响。

建议:首先,调整Java Heap的大小,以便在Full GC之后达到大约50%的OldGen占用量或占用率,为某些较高的负载情况(故障转移,峰值,繁忙的业务时段等)留有足够的缓冲区。 。

  • *热点* :注意OldGen内存泄漏!
  • 什么是Java中的内存泄漏? 随着时间的推移,实时数据不断增加

JVM_LIVE_data

实时数据深入研究

  • JVM GC日志很棒……但是如何检查实时数据呢?
  • Java堆直方图快照和堆转储分析是功能强大且行之有效的方法,可以更好地了解您的应用程序实时数据。
  • Java事件探查器解决方案和工具(例如Oracle Java Mission Control和Java Visual VM)提供了用于深度Java堆检查和性能分析的高级功能,包括跟踪应用程序内存分配。

Java_Visual_VM_histogram

世界各地的收藏:GC开销

  • YoungGen收集的价格较低,但要注意分配率过高。
  • 建议最初将YoungGen的大小(JVM默认)设置为堆大小的1/3。
  • 请记住:YoungGen和OldGen集合都是世界停止的事件!
  • PermGen和Metaspace(JDK 1.8+)是在Full GC期间收集的,因此,跟踪Class元数据足迹和GC频率非常重要。

JVM_GC_开销

JVM_YG_overhead

最后的话语和建议

最佳实践

  • 最佳的Java性能不仅与Java有关……从各个角度进行探讨。
  • 始终依靠事实而非猜测。
  • 首先要关注全局调整项,而过早要进行细粒度的优化。
  • 在适用时执行性能和负载测试。
  • 充分利用可靠的工具和故障排除技术。

避免

  • 有许多可能的JVM参数:不要过度调整JVM!
  • 您总是担心自己不了解的内容:良好的应用程序知识>无需恐惧>更好的调优建议。
  • 永远不要以为您的应用程序性能是最佳的。
  • 不要试图立即解决所有问题,而要逐步进行调整。
  • 不要感到困惑,要专注于性能问题的根本原因而不是症状。
  • 过度尝试和错误的方法:猜测的症状。

翻译自: https://www.javacodegeeks.com/2015/07/jvm-buzzwords-java-developers-should-understand.html

java 开发 jvm

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/337178.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

C/C++在Java、Android和Objective-C三大平台下实现混合编程

点击蓝字关注我们因公众号更改推送规则,请点“在看”并加“星标”第一时间获取精彩技术分享来源于网络,侵删Android和iOS开发都支持C开发,可以一套代码多平台使用。同时C难以反编译的特性也可以为Android开发带来代码的保密,另一n…

Linux Shell 004-四则运算

Linux Shell 004-四则运算 本节关键字:Linux、Bash Shell、四则运算 相关指令:echo、let、set、unset Bash Shell支持的四则运算 算术运算:默认情况下,shell就只能支持简单的整数运算 运算内容:加(&…

vs不一致的行尾对话框怎么调出_SolidWorks工程图打开后图纸没有了空白了怎么办?还能找回来吗?...

SolidWorks工程图打开后图纸没有了空白了怎么办?还能找回来吗?答案是肯定的。不知道大家使用SolidWorks有没有遇到这种情况,如下图所示:就是我们本来画好标注好的工程图,竟然没了,怎么造成的呢?…

jpa 忽略bean_在WildFly上将JPA和CDI Bean与骆驼一起使用

jpa 忽略bean我并没有真正为此计划,但是在一个免费的会议月份中,我有机会进行了一些深入的探讨,并向您展示了WildFly-Camel子系统提供的WildFly魔术上的更多Camel。 商业背景 该演示来自Christina Lin在JBoss Demo-Central上的一个演示 。 她…

【如何系统地学习 C++ 语言】关于C++,有哪些你需要提前知道的知识?

点击蓝字关注我们因公众号更改推送规则,请点“在看”并加“星标”第一时间获取精彩技术分享来源于网络,侵删C是一种通用的、面向对象的编程语言,可用于开发操作系统、游戏、图形用户界面、后端以及高性能系统和应用程序。所以,尽管…

python rsa加密之后byte类型存储到数据库中_python3 rsa加密

遇到了跟你一样的问题。 此js封装的源码 如下。希望看到的大神解决了的话帮我一下。/*RSA, a suite of routines for performing RSA public-key computations in JavaScript.Copyright 1998-2005 David Shapiro.Dave Shapirodaveohdave.comchanged by Fuchun, 2010-05-06fcrpg…

jdk 11 模块系统_JDK 9:模块系统状态的重点

jdk 11 模块系统马克雷因霍尔德 ( Mark Reinhold )的“模块系统状态 (SOMS)”已于本月初发布,它提供了信息丰富的可读性“对Jigsaw项目中原型的Java SE平台进行了增强的非正式概述,并被提议作为JSR 376的起…

【如何系统地学习 C++ 语言】从开发环境到C++进阶,应该怎么办?

点击蓝字关注我们因公众号更改推送规则,请点“在看”并加“星标”第一时间获取精彩技术分享来源于网络,侵删开发环境如前面介绍的那样,C属于一种静态的编译型语言,所以,开发环境配置过程中就需要用到对应的编译器。C有…

小学生在家自学python_小学生都能学会的python(函数)

小学生都能学会的python(函数)神马是函数函数: 对功能或者动作的封装函数的定义def 函数名(形参列表):函数体(return)ret 函数名(实参列表)函数的返回值return,只要执行到return 函数的本次调用就会被停止1.如果函数不写return, 没有返回值。…

高度可定制化的方案_如何开发高度可定制的产品

高度可定制化的方案您是否听说过:“我们非常喜欢您的产品……除了一些小细节。”? 然后,CIO推出了一系列其他“必备”要求的清单,其中有数百个要添加到您的惊人产品中。 您是否听说过,甚至说过:“团队&…

文言文编程?厉害了程序员!

点击蓝字关注我们因公众号更改推送规则,请点“在看”并加“星标”第一时间获取精彩技术分享来源于网络,侵删你能看出来,这首诗妙在哪里吗?来源:量子位(ID:QbitAI),梦晨 萧…

sublime快捷键代码对齐_Python配置sublime运行环境

1、下载安装python和sublime,不再赘述,官网即可下载;2、打开subilme,打开Tools > Build System > New Build System..3、点击New Build System后,会生成一个空配置文件,在这个配置文件内覆盖配置信息…

C语言贪心算法

点击蓝字关注我们因公众号更改推送规则,请点“在看”并加“星标”第一时间获取精彩技术分享来源于网络,侵删01基本概念贪心算法是指在对问题求解时,总是做出在当前看来是最好的选择。也就是说,不从整体最优上加以考虑,…

spark有什么作用_Spark 101:它是什么,它做什么以及为什么起作用

spark有什么作用最近,许多大数据的讨论都使用了新名称。 有人认为流行的新手Apache Spark ™是Hadoop的更易访问,更强大的替代品, Hadoop是大数据的首选原始技术。 其他人则认为Spark是Hadoop和其他技术的有力补充,它具有自己的优…

python中比较运算符怎么使用_实例说明Python中比较运算符的使用

下表列出了所有Python语言支持的比较操作符。假设变量a持有10和变量b持有20,则:例如:试试下面的例子就明白了所有的Python编程语言提供的比较操作符:#!/usr/bin/pythona 21b 10c 0if ( a b ):print "Line 1 - a is equal…

C++最佳实践 | 可维护性

点击蓝字关注我们因公众号更改推送规则,请点“在看”并加“星标”第一时间获取精彩技术分享来源于网络,侵删C最佳实践:1. 工具2. 代码风格3. 安全性4. 可维护性(本文)5. 可移植性及多线程6. 性能7. 正确性和脚本可维护性避免使用编…

rx.observable_使用Java 8 CompletableFuture和Rx-Java Observable

rx.observable我想探索一个使用Java 8 CompletableFuture和Rx-Java Observable的简单分散聚集场景。 场景很简单–产生大约10个任务,每个任务返回一个字符串,最终将结果收集到一个列表中。 顺序的 其顺序版本如下: public void testSequen…

springboot启动自动关闭_App自动化测试用例格式和App的启动与关闭

【一】基本的用例格式这里使用unittest测试框架来编写用例。注:unittest可以提供用例的组织和管理、预期结果验证、批量化运行、产生测试报告等功能。新建一个calculator的python package,新建一个calculator_test.py,导入以下包。按照标准的…

C++最佳实践 | 可移植性及多线程

点击蓝字关注我们因公众号更改推送规则,请点“在看”并加“星标”第一时间获取精彩技术分享来源于网络,侵删C最佳实践:1. 工具2. 代码风格3. 安全性4. 可维护性5. 可移植性及多线程(本文)6. 性能7. 正确性和脚本可移植性明确使用的…

eap aka_使用API​​密钥(aka身份验证令牌)部署到Maven Central

eap aka如何在不使用未加密本地密码的情况下与Maven Central / Nexus通信(尤其是使用Gradle,但不仅限于此)。 基本原理 不幸的是,Gradle(和许多其他构建工具)没有提供任何机制来本地加密密码(或…