面试官追问的STW,到底什么是STW?有什么影响?

STW,即Stop-The-World的缩写,指的是系统在执行特定操作时需暂停(停止)所有应用程序线程。

这个概念在早起文章中

Java虚拟机之垃圾收集算法

有提到过(如图)。

也有在文章

学习笔记之JVM调优之调优案例让你吊打面试官

提到过(如图):

所以感兴趣的小伙伴可以去看下往期文章。

步入正题

所谓的**STW,**在Java中,当需要执行垃圾回收时,垃圾回收器会停止应用程序的所有线程,以便安全地识别和回收不再使用的对象。这个过程被称为"Stop The World"。

STW事件会暂时中断应用程序的运行。对于需要高响应性或实时性能的应用程序,这可能引发性能问题,因为它会导致响应延迟。

在STW期间,应用程序的响应时间(RT)和吞吐量(QPS)都会受到影响,这可能导致性能表现的不确定性,特别是在负载较高的情况下。

为了减少STW带来的影响,需要对垃圾收集器的配置进行优化,例如选择不同类型的垃圾收集器、调整堆大小或其他垃圾收集器参数。

例如,选择并发回收器作为垃圾回收器,如CMSG1等,因为并发回收器主要关注的是减少STW的时长。它允许垃圾收集线程在应用程序线程运行的同时执行部分垃圾收集工作,从而减少了STW的时间。在并发回收期间,只会在特定的收集阶段发生短暂的STW。

关于Java虚拟机的垃圾收集器可参考文章

带你走近Java虚拟机到底有哪些经典的垃圾收集器

其它STW场景

除了垃圾收集(GC)中的STW事件之外,STW这个术语在其他上下文中也可能被引用。

举例来说:

  1. 操作系统和硬件升级/维护:在执行操作系统升级或硬件维护时,可能需要完全暂停系统功能,以确保安全地进行更新和维护。这种情况下的STW意味着所有在系统上运行的应用和服务都会被临时停止。
  2. 数据库维护:在某些数据库操作中,如重组索引、执行特定类型的备份或升级数据库系统时,可能需要暂时停止数据库服务,这也可以被视为一种STW事件,因为它会中断所有数据库操作。
  3. 消息队列的重新平衡:在分布式消息队列系统(例如Kafka)中,重新平衡是指在消费者群体中添加或删除消费者时重新分配分区的过程。在这个过程中,消息消费可能会暂时停止,直到重新平衡完成,确保所有分区正确地重新分配给新的消费者群体。

如有问题,欢迎加微信交流:w714771310,备注- 技术交流 。或微信搜索【码上遇见你】。

免费的Chat GPT可微信搜索【AI贝塔】进行体验,无限使用。

好了,本章节到此告一段落。希望对你有所帮助,祝学习顺利。

相关推荐
许野平29 分钟前
Rust: 利用 chrono 库实现日期和字符串互相转换
开发语言·后端·rust·字符串·转换·日期·chrono
独行soc2 小时前
#渗透测试#SRC漏洞挖掘#深入挖掘XSS漏洞02之测试流程
web安全·面试·渗透测试·xss·漏洞挖掘·1024程序员节
理想不理想v2 小时前
‌Vue 3相比Vue 2的主要改进‌?
前端·javascript·vue.js·面试
齐 飞2 小时前
MongoDB笔记01-概念与安装
前端·数据库·笔记·后端·mongodb
LunarCod2 小时前
WorkFlow源码剖析——Communicator之TCPServer(中)
后端·workflow·c/c++·网络框架·源码剖析·高性能高并发
sszmvb12343 小时前
测试开发 | 电商业务性能测试: Jmeter 参数化功能实现注册登录的数据驱动
jmeter·面试·职场和发展
码农派大星。3 小时前
Spring Boot 配置文件
java·spring boot·后端
测试杂货铺3 小时前
外包干了2年,快要废了。。
自动化测试·软件测试·python·功能测试·测试工具·面试·职场和发展
王佑辉3 小时前
【redis】redis缓存和数据库保证一致性的方案
redis·面试
真忒修斯之船3 小时前
大模型分布式训练并行技术(三)流水线并行
面试·llm·aigc