大屏可视化分配率是什么意思_什么是分配率?

大屏可视化分配率是什么意思

Java分配率 诸如“不可持续的分配率”和“您需要保持较低的分配率”之类的短语似乎仅属于Java Champions的词汇表。 复杂,恐怖并被魔术光环包围。

经常发生的情况是,当您更仔细地查看概念时,魔术会随着抽烟消失。 这篇文章试图从提到的条款中删除魔术。

什么是分配率?我为什么要关心?

分配率以每个时间单位分配的内存量来衡量。 通常以MB /秒表示,但如果您愿意,可以每年使用PB。 这就是全部–没有魔术,只是您在一段时间内在Java代码中分配的内存量。

但是,仅了解这一事实并不太有益。 如果您可以忍受我,我将指导您实际使用该概念。

面对高分配率可能会给您的应用程序性能带来麻烦。 从实际的角度来看, 垃圾收集已成为瓶颈,从而浮出水面。 从硬件的角度来看,即使是商用硬件也可以维持每个内核数GB /秒的分配,因此,如果您的速率开始不超过1 GB /秒/核,您可以放心,您的硬件实际上不会成为瓶颈。

因此,在关注GC时,我们可以从一个在现实世界中也适用的类比开始-如果您创建很多东西,那么之后往往会面临很多清理工作。 知道JVM是使用垃圾收集机制构建的,因此需要研究分配速率如何更改GC暂停的频率或持续时间。

衡量分配率

让我们从分配率的测量开始。 为此,我们通过为JVM指定-XX:+ PrintGCDetails -XX:+ PrintGCTimeStamps标志来打开GC日志记录。 JVM现在以与以下代码段类似的方式开始记录GC暂停:

0.291: [GC (Allocation Failure) [PSYoungGen: 33280K->5088K(38400K)] 33280K->24360K(125952K), 0.0365286 secs] [Times: user=0.11 sys=0.02, real=0.04 secs] 
0.446: [GC (Allocation Failure) [PSYoungGen: 38368K->5120K(71680K)] 57640K->46240K(159232K), 0.0456796 secs] [Times: user=0.15 sys=0.02, real=0.04 secs] 
0.829: [GC (Allocation Failure) [PSYoungGen: 71680K->5120K(71680K)] 112800K->81912K(159232K), 0.0861795 secs] [Times: user=0.23 sys=0.03, real=0.09 secs]

从上面的GC日志中, 我们可以将分配率计算为上一个收集完成后和下一个收集开始之前的年轻代大小之间的差。 使用上面的示例,我们可以例如提取以下信息:

  • JVM启动后的291 ms ,创建33,280K 个对象。 第一个次要的GC事件清除了Young一代,此后,Young一代还剩下5,088K个对象。
  • 发射后446毫秒,Young gen占用已增加到38,368K, 触发了下一个GC,从而将Young Gen的占用减少到了5,120K
  • 发射后829毫秒,Young gen大小为71,680K ,GC再次将减小为5,120K

然后可以在下表中表示此数据,将分配率计算为年轻入住率的增量:

事件 时间 年轻之前 年轻之后 分配期间 分配率
第一GC 291毫秒 33,280KB 5,088KB 33,280KB 114MB /秒
第二GC 446毫秒 38,368KB 5,120KB 33,280KB 215MB /秒
第三GC 829毫秒 71,680KB 5,120KB 66,560KB 174MB /秒
829毫秒 不适用 不适用 133,120KB 161MB /秒

有了这些信息,我们可以说该特定软件在测量期间的分配速率为161 MB /秒。

分析影响

现在,有了这些信息,我们就可以了解分配速率的变化如何通过增加或减少GC暂停的频率来影响应用程序吞吐量。 首先,您应该注意到只有Minor GC暂停清洁Young Generation会受到影响。 GC暂停清理旧一代的频率或持续时间不受分配率的直接影响,而受晋升率的直接影响,我们将在下一篇文章中介绍这一术语。

知道我们只能专注于次要GC暂停时,我们接下来应该查看Young Generation内部的不同内存池。 当分配在Eden中进行时 ,我们可以立即查看Eden的大小如何影响分配率。 因此,我们可以有一个假设,即增加Eden的大小将减少较小的GC暂停频率,从而使应用程序能够维持更快的分配速率。

实际上,当使用-XX:NewSize -XX:MaxNewSize和-XX:SurvivorRatio参数运行具有不同Eden大小的相同示例时,我们可以看到分配率有两倍的差异

  • 使用100M的Eden运行上述示例,将分配速率降低到100MB / sec以下
  • 将Eden大小增加到1GB,可以将分配速率增加到刚好低于200MB /秒。

如果您仍然想知道为什么这是正确的- 如果您不频繁地停止GC的应用程序线程,则可以做更多有用的工作。 还发生了更多有用的工作来创建更多对象,从而支持增加的分配率

现在,在得出“更大的伊甸园更好”的结论之前,您应该注意到分配率可能并且可能与应用程序的实际吞吐量没有直接关系。 这是一项技术指标,有助于提高吞吐量。 分配率可能会并且会影响您的次要GC暂停停止应用程序线程的频率,但是要查看整体影响,您还需要考虑主要GC暂停并以应用程序的业务操作(不是MB / sec)来衡量吞吐量。提供。

翻译自: https://www.javacodegeeks.com/2015/09/what-is-allocation-rate.html

大屏可视化分配率是什么意思

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

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

相关文章

C/C++语言动态开辟的杨辉三角

点击蓝字关注我们问题引入杨辉三角相必大家并不陌生,第1行有1列、第二行有2列…第n行有n列,且每行行首和行尾的值都为1,其余的值为上一行两数相加我们在C语言阶段,第一次碰到的杨辉三角应该都是用常规的二维数组存储,可…

git gui 历史版本_这些Git命令都不会,还是不要去面试了

前言以下,项目中经常使用的Git命令,汇总到这里以便与你能快速的学习和掌握Git命令,在文章最后有惊喜哟,一定要看到最后啊!使用的 Git版本:git version 2.24.0命令git log# 输出概要日志,这条命令等同于# gi…

java restful_Java EE中的RESTful计时器

java restful在这篇文章中...。 EJB计时器旋风之旅 通过带有示例实现的简单REST接口即时使用EJB计时器 更新(2015年7月14日) 该应用程序的前端现在可以在OpenShift上使用 。 由于我是前端新手,因此我在其他来源的帮助下组装了此HTML5 Ang…

【lua学习】1.源码组织

虚拟机核心相关文件列表内嵌库相关文件解释器,字节码编译器相关的文件做cocos2d-x lua已经有一段时间了,想更深入了解lua。我会出一系列地 自身学习过程中地解读。我会带大家沿着源码来逐步解读lua,我喜欢按照 深度优先遍历的顺序来解读源码&…

c# 联合halcon 基于相关性 模板匹配_机器视觉之halcon入门(5)-字符识别exe生成...

2.3.2 第二个halcon程序转EXE程序:字符识别老规矩,每一段halcon代码得用C#二次开发下。根据上一节所教的,我们配置下C#的环境,顺便添加好控件,如下图(2-3-2-1)。图 2-3-2-1控件基本跟上一节一样,只是少了一…

C语言数据的存储和取出(超详细讲解)

点击蓝字关注我们整形的储存我们知道一个整形的存储是以补码的形式储存取出是原码的形式。比如:int a 5;的二进制是101那它的原码应该是:00000000 00000000 00000000 00000101正数的原反补相同那它存进去和取出来都是:00000000 00000000 000…

go语言 不支持动态加载_动态语言支持

go语言 不支持动态加载本文是我们名为“ 高级Java ”的学院课程的一部分。 本课程旨在帮助您最有效地使用Java。 它讨论了高级主题,包括对象创建,并发,序列化,反射等。 它将指导您完成Java掌握的旅程! 在这里查看 &am…

【lua学习】2.数据类型

【lua学习】2.数据类型Lua中的数据类型关于TValue自顶向下分析TValue表示所有的Lua数据结构并带一个类型字段Value表示所有的Lua数据结构GCObject表示所有需要进行垃圾回收的数据结构GCheader表示需要GC的数据结构最开始的部分Lua中的数据类型 宏名 (见lua.h)宏值类型对应数据…

打印pdf就一页_PDF 文件转换工具

是将 PDF 文件转换为完全可编辑的 Windows 文档最好的转换软件。无论您需要您的内容是 Microsoft Word、Excel、PowerPoint、HTML 还是仅需要文本, 总会给您一个简单的方法,快捷地获取您要的内容。可转换整个文档或选择内容。亦可创建 PDF 文件。PDF 转换…

C++类的this指针,静态成员,友元函数友元类

点击蓝字关注我们1. this指针在上篇讲C中类,对象,封装,继承(派生),多态的时候,this指针出现在成员函数中,并使用->成员提取符操作成员变量。在 C 中,每一个对象都能通…

jooq和jdbc_将jOOQ与JDBC比较

jooq和jdbc本文是我们学院课程“ jOOQ –类型安全数据库查询”的一部分 。 在SQL和特定关系数据库很重要的Java应用程序中,jOOQ是一个不错的选择。 当JPA / Hibernate抽象过多而JDBC过于抽象时,这是一种替代方法。 它显示了一种现代的领域特定语言如何可…

【lua学习】3.字符串

【lua学习】3.字符串Lua字符串的概况字符串实现字符串结构TString全局字符串表stringtable新建字符串luaS_newlstr (先查表,再决定创建与否)新建字符串 newlstr重新设置全局字符串的大小 luaS_resize全局字符串表的缩容保留字是如何不被回收的…

【lua学习】4.表

1 概述2 数据结构2.1.表Table2.2 键TKey2.3 节点(键值对)Node3 操作算法3.1 查找3.1.1 通用查找luaH_get3.1.2 根据字符串查找 luaH_getstr3.1.3 根据整数查找 luaH_getnum3.2 新增元素/修改元素/删除元素 luaH_set系列3.2.1 根据key获取或创建一个value…

批量提取文件创建时间_批量采集新浪微博用户内容

有时我们需要把某些用户的微博数据全部采集下来用作分析,每条信息复制的工作量是非常低效的,必须要借助工具。今天给大家介绍一款采集软件:微风采集器。打开软件,选择模板,下拉框选:批量提取指定用户微博内…

C++异常的规则

点击蓝字关注我们异常是指存在于程序运行时的异常行为,这些行为超出了函数正常功能的范围,当程序的某部分检测到一个无法处理的问题时,就需要用到异常处理。1. C语言中传统的处理错误方式终止程序:如assert,当发生错误…

java中集合选取怎么选_集合中的可选

java中集合选取怎么选有时有人认为Optional类型值得在集合中使用。 据称&#xff0c;它解决了以下问题&#xff1a; HashMap在没有键映射以及值null映射到键的情况下返回null 。 如果使用Map<Optional<Something>>则可以清楚地区分缺少的映射和缺少的值。 这样一来…

【lua学习】7.环境

1 最重要的两个数据结构1.1 lua_State(Lua虚拟机/Lua协程)1.2 global_State(Lua全局状态)2 环境相关的变量2.1 Global表2.1.1 Global表在lua_State结构中2.1.2 Global表在 f_luaopen 时被初始化2.2 env表2.2.1 env表在Closure结构中2.2.2 查找一个全局变量<>在当前函数的…

异质性查询需要为连线设定_振奋人心!华东理工大学开发新型的荧光染料,为细胞成像奠定基础...

结合并激活荧光染料的适体荧光RNA(FR)已用于对丰富的细胞RNA种类进行成像。然而&#xff0c;诸如低亮度和具有不同光谱特性的染料/适体组合的有限可用性的局限性&#xff0c;限制了这些工具在活的哺乳动物细胞和体内的使用。最近&#xff0c;华东理工大学朱麟勇及杨弋共同通讯在…

C++ STL详解(1)

点击蓝字关注我们概述STL 是“Standard Template Library”的缩写&#xff0c;中文译为“标准模板库”。STL 是 C 标准库的一部分&#xff0c;不用单独安装。C 对模板&#xff08;Template&#xff09;支持得很好&#xff0c;STL 就是借助模板把常用的数据结构及其算法都实现了…

jooq 配置oracle_jOOQ配置

jooq 配置oracle本文是我们学院课程“ jOOQ –类型安全数据库查询”的一部分 。 在SQL和特定关系数据库很重要的Java应用程序中&#xff0c;jOOQ是一个不错的选择。 当JPA / Hibernate抽象过多而JDBC过于抽象时&#xff0c;这是一种替代方法。 它显示了一种现代的领域特定语言…