GC当中吞吐量和暂停时间的区别

GC当中吞吐量和暂停时间的区别是:吞吐量就是 CPU 用于运行用户代码的时间与 CPU 总消耗时间的比值,即吞吐量 = 运行用户代码时间 /(运行用户代码时间 + 垃圾收集时间)。“暂停时间” 是指一个时间段内应用程序线程暂停,让 GC 线程执行的状态。

GC当中吞吐量和暂停时间的区别-Worktile社区

吞吐量(throughput)

吞吐量就是 CPU 用于运行用户代码的时间与 CPU 总消耗时间的比值,即吞吐量 = 运行用户代码时间 /(运行用户代码时间 + 垃圾收集时间)

比如:虚拟机总共运行了 100 分钟,其中垃圾收集花掉 1 分钟,那吞吐量就是 99%

这种情况下,应用程序能容忍较高的暂停时间,因此,高吞吐量的应用程序有更长的时间基准,快速响应是不必考虑的

吞吐量优先,意味着在单位时间内,STW 的时间最短:0.2 + 0.2 = 0.4

暂停时间(pause time)

“暂停时间” 是指一个时间段内应用程序线程暂停,让 GC 线程执行的状态

例如,GC 期间 100 毫秒的暂停时间意味着在这 100 毫秒期间内没有应用程序线程是活动的

暂停时间优先,意味着尽可能让单次 STW 的时间最短:0.1+ 0.1+ 0.1 +0.1+0.1 = 0.5

吞吐量与暂停时间的对比

高吞吐量较好因为这会让应用程序的最终用户感觉只有应用程序线程在做 “生产性” 工作。直觉上,吞吐量越高程序运行越快

低暂停时间(低延迟)较好因为从最终用户的角度来看不管是 GC 还是其他原因导致一个应用被挂起始终是不好的。这取决于应用程序的类型,有时候甚至短暂的 200 毫秒暂停都可能打断终端用户体验。因此,具有低的较大暂停时间是非常重要的,特别是对于一个交互式应用程序

不幸的是 “高吞吐量” 和 “低暂停时间” 是一对相互竞争的目标(矛盾)

因为如果选择以吞吐量优先,那么必然需要降低内存回收的执行频率,但是这样会导致 GC 需要更长的暂停时间来执行内存回收

相反的,如果选择以低延迟优先为原则,那么为了降低每次执行内存回收时的暂停时间,也只能频繁地执行内存回收,但这又引起了年轻代内存的缩减和导致程序吞吐量的下降

在设计(或使用) GC算法时,我们必须确定我们的目标: 一个 GC 算法只可能针对两个目标之一(即只专注于较大吞吐量或最小暂停时间),或尝试找到一个二者的折衷

延伸阅读:

什么是GC?

GC(Grid Communication)网格通信

网格是一种新兴的技术,正处在不断发展和变化当中。目前学术界和商业界围绕网格开展的研究有很多,其研究的内容和名称也不尽相同因而网格尚未有精确的定义和内容定位。比如国外媒体常用“下一代互联网”、“Internet2”、“下一代Web”等来称呼网格相关技术。但“下一代互联网(NGI)”和“Internet2”又是美国的两个具体科研项目的名字,它们与网格研究目标相交叉,研究内容和重点有很大不同。企业界用的名称也很多,有内容分发(Contents Delivery)、服务分发(Service Delivery)、电子服务(e-service)、实时企业计算(Real-Time Enterprise Computing,简称RTEC)、分布式计算Peer-to-Peer Computing(简称P2P)、Web服务(Web Services)等。中国科学院计算所所长李国杰院士认为,网格实际上是继传统互联网、Web之后的第三次浪潮,可以称之为第三代互联网应用。

网格是利用互联网把地理上广泛分布的各种资源(包括计算资源、存储资源、带宽资源、软件资源、数据资源、信息资源、知识资源等)连成一个逻辑整体,就像一台超级计算机一样,为用户提供一体化信息和应用服务(计算、存储、访问等),虚拟组织最终实现在这个虚拟环境下进行资源共享和协同工作,彻底消除资源“孤岛”,最充分的实现信息共享。

文章标题:GC当中吞吐量和暂停时间的区别,发布者:小编,转载请注明出处:https://worktile.com/kb/p/37795

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
小编的头像小编
上一篇 2023年2月12日 下午4:15
下一篇 2023年2月12日 下午4:18

相关推荐

  • 五行健康管理项目是什么

    五行健康管理项目是一种全新的健康管理理念,它根据中国传统五行理论(金、木、水、火、土)来制定个人的健康管理计划。五行健康管理项目主要包括以下几个方面:一、健康评估;二、个性化健康计划设计;三、执行健康计划;四、健康效果评估;五、健康管理计划调整。其中,健康评估是整个项目的基础,通过健康评估,我们可以…

    2024年8月6日
    000
  • 项目管理者需要什么证书

    对于项目管理者来说,拥有一份专业的证书可以提升其在业界的认可度和信任度。PMP(项目管理专业人员资格认证)、PRINCE2(项目内控环境)、CAPM(认证项目管理专家)、ACP(敏捷认证专家)以及CSM(认证Scrum主管)等证书都是项目管理者值得获取的。 以PMP证书为例,这是由美国项目管理协会(…

    2024年8月6日
    000
  • 项目经理是管理什么的

    项目经理是负责管理项目的专业人员,他们的主要职责是确保项目在预定的时间、预算和质量标准内完成。他们的工作涵盖了项目的所有方面,包括项目的规划、执行、控制和关闭。项目经理的主要任务包括:确定项目的目标和范围、制定详细的工作计划、管理项目的资源、监控项目的进度、处理项目中的问题和风险,以及确保项目的成功…

    2024年8月6日
    000
  • 项目化管理有什么意思呢

    项目化管理是一种以项目为主导,通过项目的规划、组织、实施和控制,实现组织目标的管理方式。它将业务流程转换为一个个独立的项目,每个项目都有明确的目标、特定的工期和预定的资源。项目化管理的核心是以项目为载体,实现组织的战略目标。 在项目化管理中,项目经理在项目期间对项目资源拥有相对完全的控制权,项目团队…

    2024年8月6日
    000
  • 自动化为什么学项目管理

    在当前的快速发展的科技环境下,项目管理已经成为实现业务目标的关键环节。自动化学习项目管理有三个主要的原因:提高工作效率、降低错误率、优化资源配置。 对于任何企业,最大化利用资源,提高工作效率是其核心的目标,而项目管理的运用则是实现这一目标的有效工具。通过自动化学习项目管理,我们可以系统地理解和应用项…

    2024年8月6日
    000

发表回复

登录后才能评论
注册PingCode 在线客服
站长微信
站长微信
电话联系

400-800-1024

工作日9:30-21:00在线

分享本页
返回顶部