Jvm 之 Stop The World 机制

这篇具有很好参考价值的文章主要介绍了Jvm 之 Stop The World 机制。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

一、STW简介

stop the world(STW)机制是指在JVM运行过程中,所有的应用线程都会被暂停,JVM会执行一些特定的任务,如垃圾回收、线程栈的调整等。

在JVM执行STW期间,所有的应用线程都会被暂停, 这样可以避免在执行关键任务时,应用线程对数据进行修改,从而确保数据的一致性。

无论选择何种垃圾收集算法,都无法完全避免STW的发生,只能尽量减少STW的时间。

此外,STW机制还可以为JVM执行一些重要的任务,如垃圾回收、内存管理等,以提高JVM的性能和效率。

二、为什么需要STW

首先,如果不暂停用户线程,就意味着在垃圾收集过程中会持续产生新的垃圾对象,无法完全清理干净。

其次,用户线程的运行必然会导致对象的引用关系发生改变,可能出现两种情况:多标和漏标

  • 多标:原本并不是垃圾对象,但在垃圾收集过程中,用户线程修改了其引用关系,导致垃圾收集器将其误认为是垃圾。这种情况相对较好,只会产生一些临时的浮动垃圾,下次垃圾收集过程时会被清理掉。

  • 漏标:原本是垃圾对象,但在垃圾收集过程中,用户线程重新将其引用指向了该对象,如果垃圾收集器错误地将其回收,将导致程序运行错误。

需要注意的是,以上情况的发生都是在垃圾收集过程中,用户线程与垃圾收集器同时运行时可能会出现的问题。调整线程栈大小等措施可以尽量减少这些问题的发生。

三、STW机制触发实际

1. 垃圾回收(GC):

当JVM执行垃圾回收时,所有的应用线程都会被暂停,以便JVM可以遍历堆中的所有对象并进行垃圾回收操作。这是因为在执行垃圾回收时,JVM需要确保所有的对象都是可达的,并且没有引用关系存在,以便正确地进行垃圾回收。

2. 类加载和卸载:

当JVM加载或卸载类时,所有的应用线程都会被暂停。这是因为在加载或卸载类时,JVM需要确保类的加载和卸载操作是原子性的,并且不会影响到其他线程的执行。

3. JIT编译:

当JVM执行即时编译(JIT)时,所有的应用线程都会被暂停。这是因为在执行JIT编译时,JVM需要确保编译过程不会影响到其他线程的执行,并且可以正确地生成优化的机器码。

四、STW带来的问题

STW(Stop-The-World)会引发以下问题:

1. 停顿时间延长:

由于STW会暂停应用程序的执行,因此会导致应用程序的停顿时间变长。这对于追求高响应性和低延迟的应用程序来说,会对用户体验造成不利影响。

2. 性能下降:

由于STW会暂停应用程序的执行,因此会导致应用程序的吞吐量下降。特别是在停顿时间较长的情况下,应用程序的性能可能会受到明显的损失。

3. 延迟累积:

在发生STW期间,应用程序的所有用户请求都被阻塞,这可能导致请求的延迟逐渐累积。如果STW发生过于频繁或持续时间过长,延迟累积可能会导致应用程序无法及时响应用户的请求。

4. 系统资源浪费:

在STW期间,垃圾回收器会占用一部分系统资源,如CPU和内存。这些资源本可以用于应用程序的执行和处理用户请求,但在STW期间被浪费掉。

为了减少STW带来的问题,Java虚拟机不断优化垃圾回收算法和机制,如引入分代垃圾回收、并行和并发垃圾回收等技术,以减少停顿时间、提高吞吐量和降低延迟累积。

五、STW总结

STW机制对于JVM的性能和效率是有一定影响的,因为在STW期间,所有的应用线程都会被暂停,导致应用程序的响应时间延长。因此,在设计和开发应用程序时,需要考虑到STW机制的影响,并采取相应的措施来减少STW的时间,提高应用程序的性能和效率。文章来源地址https://www.toymoban.com/news/detail-601050.html

到了这里,关于Jvm 之 Stop The World 机制的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • JVM基础(1)——JVM类加载机制

    作者简介:大家好,我是smart哥,前中兴通讯、美团架构师,现某互联网公司CTO 联系qq:184480602,加我进群,大家一起学习,一起进步,一起对抗互联网寒冬 学习必须往深处挖,挖的越深,基础越扎实! 阶段1、深入多线程 阶段2、深入多线程设计模式 阶段3、深入juc源码解析

    2024年02月02日
    浏览(51)
  • JVM基础(3)——JVM垃圾回收机制

    作者简介:大家好,我是smart哥,前中兴通讯、美团架构师,现某互联网公司CTO 联系qq:184480602,加我进群,大家一起学习,一起进步,一起对抗互联网寒冬 学习必须往深处挖,挖的越深,基础越扎实! 阶段1、深入多线程 阶段2、深入多线程设计模式 阶段3、深入juc源码解析

    2024年01月25日
    浏览(48)
  • 【Java高级应用:深入探索Java编程的强大功能,JVM 类加载机制, JVM 内存模型,垃圾回收机制,JVM 字节码执行,异常处理机制】

    本人详解 作者:王文峰,参加过 CSDN 2020年度博客之星,《Java王大师王天师》 公众号:JAVA开发王大师,专注于天道酬勤的 Java 开发问题 中国国学、传统文化和代码爱好者的程序人生,期待你的关注和支持!本人外号:神秘小峯 山峯 转载说明:务必注明来源(注明:作者:

    2024年01月16日
    浏览(91)
  • JVM及垃圾回收机制

    类加载器负责将.class文件加载到JVM中。主要分为三种层次:Bootstrap ClassLoader、Extension ClassLoader和Application ClassLoader。它们按层次关系加载类,保证类的隔离性和重用性。 运行时数据区包括方法区、堆、栈、本地方法栈和程序计数器。堆用于存放对象实例,方法区保存类信息和

    2024年02月12日
    浏览(42)
  • 浅谈JVM垃圾回收机制

    新生代收集(Minor GC/Young GC):只对新生代进行垃圾收集 老年代收集(Major GC/Old GC):只队老年代进行垃圾收集 混合收集(Mixed GC):对整个新生代和老年代进行垃圾收集 收集整个Java堆和方法区 空间分配担保是为了确保在Minor GC之前老年代还有容纳新生代所有对象的剩余空间 垃圾回收算

    2024年02月10日
    浏览(43)
  • 【JVM】打破双亲委派机制

           📝个人主页:五敷有你        🔥 系列专栏:JVM ⛺️ 稳中求进,晒太阳 ClassLoader包含了四个核心方法 双亲委派机制核心代码阅读 阅读双亲委派机制的核心代码,分析如何通过自定义类加载器打破双亲委派机制。 打破双亲委派机制的核心就是讲下面的代码重写

    2024年02月19日
    浏览(49)
  • 【jvm】双亲委派机制

    一、说明 1.java虚拟机对class文件采用的是按需加载的方式,当需要使用该类时才会将它的class文件加载到内存生成class对象 2.加载某个类的class文件时,java虚拟机采用双亲委派模式,即把请求交给由父类处理,是一种任务委派模式 3.jvm中表示两个class对象是否为同一个类存在两

    2024年02月11日
    浏览(42)
  • 【JVM】垃圾回收机制

     哈喽,哈喽,大家好~ 我是你们的老朋友: 保护小周ღ    今天给大家带来的是  JVM (Java 虚拟机) 的垃圾回收机制,回收是指回收什么?  如何确定要回收的内存: 引用计数,可达性分析,如何释放空间 : 标记清除,复制算法,标记整理,分代回收 ,一起来看看叭~ 本期

    2024年02月09日
    浏览(45)
  • JVM:类加载机制

    Java虚拟机把描述类的数据从Class文件加载到内存,并对数据进行校验、转换解析和初始化,最终形成可以被虚拟机直接使用的Java类型,这个过程被称作虚拟机的类加载机制。 一个类型从被加载到虚拟机内存中开始,到卸载出内存为止,它的整个生命周期将会经历 加载、验证

    2024年01月17日
    浏览(89)
  • JVM类加载机制

    自己编写的Java代码,是如何在各种各样的操作系统上运行起来的? Java文件通过javac编译成class文件,这种中间码被称为字节码,然后由jvm加载字节码,运行时解释器将字节码解释为一行行机器码来执行,在程序运行期间,即时编译器能会针对热点代码将该部分字节码编译成机

    2024年02月10日
    浏览(38)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包