当前位置:首页 > 科技  > 软件

JDK19虚线程探究

来源: 责编: 时间:2023-11-01 09:19:08 475观看
导读Part 01. 平台线程 聊虚线程之前我们先说一下JDK19之前的标准线程,在JDK19中为了区分虚线程,给它起名叫平台线程。它是对具体操作系统(OS)线程的包装,每当在JVM中创建一个平台线程,在OS中就一定有一个操作系统线程与之对

vC128资讯网——每日最新资讯28at.com

Part 01. 平台线程 

聊虚线程之前我们先说一下JDK19之前的标准线程,在JDK19中为了区分虚线程,给它起名叫平台线程。它是对具体操作系统(OS)线程的包装,每当在JVM中创建一个平台线程,在OS中就一定有一个操作系统线程与之对应,任务代码通过平台线程在底层操作系统线程上运行。由于在平台线程的整个生命周期过程中,要不停地捕获操作系统线程,也就是说平台线程要真实的绑定一个系统线程,因此应用中平台线程的数量取决于操作系统的线程数量。vC128资讯网——每日最新资讯28at.com

图1 平台线程调用示意图1 平台线程调用示意vC128资讯网——每日最新资讯28at.com

平台线程适用所有类型任务,无论是IO密集型还是计算密集型,但由于平台线程和操作系统线程绑定,当平台线程执行IO密集型任务时(需要大量等待),操作系统线程也要跟着等待,浪费很多时间在等待上,而且为了维系这种绑定关系,平台线程需要维护大型线程堆栈,操作系统也需要为平台线程维护其他资源,因此创建、调度平台线程成本很高。vC128资讯网——每日最新资讯28at.com

总之一句话,平台线程好用,但很“贵”。vC128资讯网——每日最新资讯28at.com

Part 02. 虚线程  

JDK19开始提供虚线程的预览功能,在JDK19中虚线程仍是一个java.lang.Thread实例,仍然可以使用 Thread 类和 Thread.Builder 接口创建虚拟线程,甚至在Executors上提供newVirtualThreadPerTaskExecutor方法用于创建虚拟线程,虽然创建出来的不是线程池。由此可见官方非常希望用户在JDK后续版本中使用虚线程替换平台线程。vC128资讯网——每日最新资讯28at.com

虚线程虽然也是Thread实例,但它的创建不与OS线程绑定。它是由jvm负责创建调度,不需要维护大型堆栈,更不需要底层操作系统为其维护资源。vC128资讯网——每日最新资讯28at.com

虽然虚线程不与OS线程绑定,但是提交给虚线程的任务代码仍然是跑在OS线程上的。当JVM调度一个虚线程开始任务时,会将它与一个平台线程绑定,平台线程称为虚线程的载体,虚线程开始执行任务,直到虚线被IO阻塞时,JVM再次调度虚线程,将它从平台线程挂起,此时空闲下来的平台线程就又可以与其他虚线程绑定,完成其它工作。vC128资讯网——每日最新资讯28at.com

这种设计的好处有:(1) 虚线程的的创建、挂起、恢复成本很低;(2) 虚线程数量不受操作系统线程数量限制;(3) 线程切换放在虚线程那一层级,尽量减少了平台线程的切换。vC128资讯网——每日最新资讯28at.com

图2 虚线程调用示意图2 虚线程调用示意vC128资讯网——每日最新资讯28at.com

Part 03.  平台线程与虚线程的对比  

3.1 线程的成本测试

测试目的主要为了观察平台线程与虚线程的创建成本以及调度成本,设计测试代码如下:vC128资讯网——每日最新资讯28at.com

图片图片vC128资讯网——每日最新资讯28at.com

代码很简单,构建一个task(主要是为了测试创建、切换线程的成本,因此task中不添加其他逻辑),分别创建5万个虚线程和平台线程处理task。vC128资讯网——每日最新资讯28at.com

横坐标为测试代码的时间线,绿色面积图为CPU使用率,蓝色柱状图为内存分配事件。vC128资讯网——每日最新资讯28at.com

(虚线程跑5w个任务(虚线程跑5w个任务vC128资讯网——每日最新资讯28at.com

(平台线程跑5w个任务)(平台线程跑5w个任务)vC128资讯网——每日最新资讯28at.com

从上面的图表可以看出,平台线程的创建、切换对CPU、内存的消耗远高于虚线程。vC128资讯网——每日最新资讯28at.com

3.2  吞吐量测试-IO密集型任务

吞吐量测试逻辑,测试在相同平台线程数、相同时间内哪一种线程执行的任务数量多。vC128资讯网——每日最新资讯28at.com

JVM提供了2个参数用以控制虚线程能调度的平台线程数:vC128资讯网——每日最新资讯28at.com

jdk.virtualThreadScheduler.parallelism 控制提供多少个平台线程用以虚线程调度。vC128资讯网——每日最新资讯28at.com

jdk.virtualThreadScheduler.maxPoolSize 控制最多多少个平台线程用以虚线程调度。vC128资讯网——每日最新资讯28at.com

通过设置vC128资讯网——每日最新资讯28at.com

-Djdk.virtualThreadScheduler.parallelism=1 -Djdk.virtualThreadScheduler.maxPoolSize=1参数控制,虚线程只能创建1个平台线程。vC128资讯网——每日最新资讯28at.com

设计测试代码一如下:vC128资讯网——每日最新资讯28at.com

图片图片vC128资讯网——每日最新资讯28at.com

结果如下:vC128资讯网——每日最新资讯28at.com

图片图片vC128资讯网——每日最新资讯28at.com

通过结果可以看出在IO密集型任务上,虚线程的吞吐量明显高于平台线程。vC128资讯网——每日最新资讯28at.com

3.3 吞吐量测试-计算密集型任务

测试逻辑与3.2一样,只是把任务逻辑改成模拟计算密集型。vC128资讯网——每日最新资讯28at.com

测试代码如下:vC128资讯网——每日最新资讯28at.com

图片图片vC128资讯网——每日最新资讯28at.com

运行结果:vC128资讯网——每日最新资讯28at.com

图片图片vC128资讯网——每日最新资讯28at.com

在计算密集型的任务中,平台线程与虚线程表现差不多,说明虚线程并不会比平台线程更快。vC128资讯网——每日最新资讯28at.com

各种数据源通过Kafka接入到数据平台层,数据平台讲明细数据存入数据存储层的ClickHouse中,明细数据的存活时间可以根据业务需求设置。同时可以根据业务报表查询的不同维度,利用ClickHouse的物化视图形成预聚合数据,提高数据查询效率。由数据服务层的定时任务周期性地从ClickHouse的预聚合数据中查询业务所需的展示数据,把展示数据存入MySQL。由数据服务层的报表服务向数据展示层提供查询服务,报表服务直接查询MySQL中的结果数据,保证了查询效率和并发性。vC128资讯网——每日最新资讯28at.com

Part 04. 总结 

(1)虚线程相对于平台线程更加轻量,由JVM创建、调度;vC128资讯网——每日最新资讯28at.com

(2)虚线程的调度过程中需要依赖一个平台线程(挂载、卸载);vC128资讯网——每日最新资讯28at.com

(3)虚线程在IO密集型任务中比平台线程更有优势;vC128资讯网——每日最新资讯28at.com

(4)虚线程目的不是让系统更快,而是让系统有更高的吞吐量。vC128资讯网——每日最新资讯28at.com

本文链接:http://www.28at.com/showinfo-26-16290-0.htmlJDK19虚线程探究

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: 聊聊六边形架构,对代码的编写有很好的指导作用

下一篇: 什么是自动化测试,看完你就懂了!

标签:
  • 热门焦点
  • 影音体验是真的强 简单聊聊iQOO Pad

    大公司的好处就是产品线丰富,非常细分化的东西也能给你做出来,例如早先我们看到了新的vivo Pad2,之后我们又在iQOO Neo8 Pro的发布会上看到了iQOO的首款平板产品iQOO Pad。虽
  • JavaScript 混淆及反混淆代码工具

    介绍在我们开始学习反混淆之前,我们首先要了解一下代码混淆。如果不了解代码是如何混淆的,我们可能无法成功对代码进行反混淆,尤其是使用自定义混淆器对其进行混淆时。什么是混
  • 一文看懂为苹果Vision Pro开发应用程序

    译者 | 布加迪审校 | 重楼苹果的Vision Pro是一款混合现实(MR)头戴设备。Vision Pro结合了虚拟现实(VR)和增强现实(AR)的沉浸感。其高分辨率显示屏、先进的传感器和强大的处理能力
  • K8S | Service服务发现

    一、背景在微服务架构中,这里以开发环境「Dev」为基础来描述,在K8S集群中通常会开放:路由网关、注册中心、配置中心等相关服务,可以被集群外部访问;图片对于测试「Tes」环境或者
  • 华为发布HarmonyOS 4:更好玩、更流畅、更安全

    在8月4日的华为开发者大会2023(HDC.Together)大会上,HarmonyOS 4正式发布。自2019年发布以来,HarmonyOS一直以用户为中心,经历四年多的发展HarmonyOS已
  • 三星Galaxy Z Fold5今日亮相:厚度缩减但仍略显厚重

    据官方此前宣布,三星将于7月26日也就是今天在韩国首尔举办Unpacked活动,届时将带来带来包括Galaxy Buds 3、Galaxy Watch 6、Galaxy Tab S9、Galaxy
  • 自研Exynos回归!三星Galaxy S24系列将提供Exynos和骁龙双版本

    年初,全新的三星Galaxy S23系列发布,包含Galaxy S23、Galaxy S23+和Galaxy S23 Ultra三个版本,全系搭载超频版骁龙8 Gen 2,虽同样采用台积电4nm工艺制
  • 朋友圈可以修改可见范围了 苹果用户可率先体验

    近日,iOS用户迎来微信8.0.27正式版更新,除了可更换二维码背景外,还新增了多项实用功能。在新版微信中,朋友圈终于可以修改可见范围,简单来说就是已发布的朋友圈
  • 微软发布Windows 11新版 引入全新任务栏状态

    近日,微软发布了Windows 11新版,而Build 22563更新主要引入了几周前曝光的平板模式任务栏等,系统更流畅了。更新中,Windows 11加入了专门针对平板优化的任务栏
Top