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

JDK21 性能提升20倍

来源: 责编: 时间:2023-10-20 10:02:04 376观看
导读大家好,我是了不起。JDK21 发布已经过去1个月时间了,除了每次发版必然更新的GC机制,和一些增强功能外,还引入了一个全新的概念——虚拟线程。什么是虚拟线程先来看一下官方对虚拟线程(Visual Threads)的描述(已翻译):如今,JD

大家好,我是了不起。wGg28资讯网——每日最新资讯28at.com

JDK21 发布已经过去1个月时间了,除了每次发版必然更新的GC机制,和一些增强功能外,还引入了一个全新的概念——虚拟线程。wGg28资讯网——每日最新资讯28at.com

什么是虚拟线程

先来看一下官方对虚拟线程(Visual Threads)的描述(已翻译):wGg28资讯网——每日最新资讯28at.com

如今,JDK中java.lang.Thread的每个实例都是一个平台线程。平台线程在底层操作系统线程上运行Java代码,并在代码的整个生命周期中捕获操作系统线程。平台线程的数量限制为操作系统线程的数量。wGg28资讯网——每日最新资讯28at.com

虚拟线程是java.lang.thread的一个实例,它在底层操作系统线程上运行java代码,但在代码的整个生命周期内不会捕获该操作系统线程。这意味着许多虚拟线程可以在同一个操作系统线程上运行Java代码,从而有效地共享代码。wGg28资讯网——每日最新资讯28at.com

虽然平台线程独占了宝贵的操作系统线程,但虚拟线程却没有。虚拟线程的数量可以比操作系统线程的数量大得多。wGg28资讯网——每日最新资讯28at.com

虚拟线程是JDK而不是OS提供的线程的轻量级实现。它们是用户模式线程的一种形式,在其他多线程语言中也很成功(例如Go中的goroutines和Erlang中的processes)。用户模式线程甚至在早期版本的Java中被称为“绿色线程”,当时操作系统线程还不成熟和广泛使用。然而,Java的绿色线程都共享一个操作系统线程(M:1调度),并且最终被平台线程所超越,后者被实现为操作系统线程的包装器(1:1调度)。虚拟线程采用M:N调度,其中大量(M)虚拟线程被调度在少量(N)OS线程上运行。wGg28资讯网——每日最新资讯28at.com

简而言之,现在我们可以轻松地创建一个轻量级的虚拟线程,实现简单性,同时充分发挥硬件性能。wGg28资讯网——每日最新资讯28at.com

可以概括为: 轻量、多路复用、开销极小、异步编程、可移植性wGg28资讯网——每日最新资讯28at.com

测试

开始一个简单的测试:1万并发阻塞1秒模仿web连接池,使用Thread.sleep(1) 模拟IO操作需要的时间。wGg28资讯网——每日最新资讯28at.com

public static void main(String[] args) throws InterruptedException {    long l = System.currentTimeMillis();//    normal();    virtual();    System.out.println(System.currentTimeMillis() - l);}

先使用常规线程池方式运行:wGg28资讯网——每日最新资讯28at.com

public static void normal() throws InterruptedException {    ExecutorService executor = Executors.newFixedThreadPool(200);    for (int i=0; i < 10000; i++) {        executor.execute(() -> {            try {                System.out.println("normal");                Thread.sleep(1000);            } catch (InterruptedException e) {                e.printStackTrace();            }        });    }    executor.shutdown();    executor.awaitTermination(100, java.util.concurrent.TimeUnit.SECONDS);}

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

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

使用 JDK21 虚拟线程池运行:wGg28资讯网——每日最新资讯28at.com

public static void virtual() throws InterruptedException {    ExecutorService executor = Executors.newVirtualThreadPerTaskExecutor();    for (int i=0; i < 10000; i++) {        executor.execute(() -> {            try {                System.out.println("jdk21");                Thread.sleep(1000);            } catch (InterruptedException e) {                e.printStackTrace();            }        });    }    executor.shutdown();    executor.awaitTermination(100, java.util.concurrent.TimeUnit.SECONDS);}

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

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

20多倍的提速!!!wGg28资讯网——每日最新资讯28at.com

我不理解,但我大受震撼!!!wGg28资讯网——每日最新资讯28at.com

如果有朋友想自己测试一下虚拟线程,或者JDK21的其他新特性,可以尝试一下哦~wGg28资讯网——每日最新资讯28at.com

JDK21 官网下载链接:https://download.oracle.com/graalvm/21/latest/graalvm-jdk-21_windows-x64_bin.zipwGg28资讯网——每日最新资讯28at.com

目前虚拟线程还属于预览版本,没有正式启用。如果是IDEA 开发工具,在启动的时候,需要配置VM参数 --enable-previewwGg28资讯网——每日最新资讯28at.com

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

小结

经过测试,在该例子中,Executors.newFixedThreadPool( size ); size的值越大,普通的线程池用时越短,在线程池的大小开放到 10000后,用时几乎一样。wGg28资讯网——每日最新资讯28at.com

应该是本例的IO操作是Thread.sleep的缘故,所以不会占用CPU资源。wGg28资讯网——每日最新资讯28at.com

传统的线程池,一般我们会指定核心线程数量为 CPU核心数*4,最大线程数为 CPU核心数*8,而在虚拟线程池中,不需要指定线程数,JDK会自动根据资源占用情况,创建合适数量的线程,追求更高的吞吐量。wGg28资讯网——每日最新资讯28at.com

听说springboot3.2.0版本开始,springboot要把webflux底层也改成虚拟线程了,不知道以后会不会把所有的关于异步线程的地方都改成虚拟线程。wGg28资讯网——每日最新资讯28at.com

了不起是觉得这个虚拟线程真是个好东西,简单易用,再也不纠结怎么配置线程池,根据硬件自适应,效率极高。wGg28资讯网——每日最新资讯28at.com

现在Spring6是基于JDK17的,不知道下个大版本更新会不会直接更新到有虚拟线程稳定发布的JDK版本,期待!wGg28资讯网——每日最新资讯28at.com

本文链接:http://www.28at.com/showinfo-26-14296-0.htmlJDK21 性能提升20倍

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

上一篇: 携程火车票异常检测和根因定位实践

下一篇: 为啥有的ConfigMap要重启Pod才生效

标签:
  • 热门焦点
  • Find N3入网:最高支持16+1TB

    OPPO将于近期登场的Find N3折叠屏目前已经正式入网,型号为PHN110。本次Find N3在外观方面相比前两代有很大的变化,不再是小号的横向折叠屏,而是跟别的厂商一样采用了较为常见的
  • 中兴AX5400Pro+上手体验:再升级 双2.5G网口+USB 3.0这次全都有

    2021年11月的时候,中兴先后发布了两款路由器产品,中兴AX5400和中兴AX5400 Pro,从产品命名上就不难看出这是隶属于同一系列的,但在外观设计上这两款产品可以说是完全没一点关系
  • Flowable工作流引擎的科普与实践

    一.引言当我们在日常工作和业务中需要进行各种审批流程时,可能会面临一系列技术和业务上的挑战。手动处理这些审批流程可能会导致开发成本的增加以及业务复杂度的上升。在这
  • 谷歌KDD'23工作:如何提升推荐系统Ranking模型训练稳定性

    谷歌在KDD 2023发表了一篇工作,探索了推荐系统ranking模型的训练稳定性问题,分析了造成训练稳定性存在问题的潜在原因,以及现有的一些提升模型稳定性方法的不足,并提出了一种新
  • 一个注解实现接口幂等,这样才优雅!

    场景码猿慢病云管理系统中其实高并发的场景不是很多,没有必要每个接口都去考虑并发高的场景,比如添加住院患者的这个接口,具体的业务代码就不贴了,业务伪代码如下:图片上述代码有
  • 重估百度丨“晚熟”的百度云,能等到春天吗?

    &copy;自象限原创作者|程心排版|王喻可2016年7月13日,百度云计算战略发布会在北京举行,宣告着百度智能云的正式启程。彼时的会场座无虚席,甚至排队排到了门外,在场的所有人几乎都
  • 10天营收超1亿美元,《星铁》比《原神》差在哪?

    来源:伯虎财经作者:陈平安即便你没玩过《原神》,你一定听说过的它的大名。恨它的人把《原神》开服那天称作是中国游戏史上最黑暗的一天,有粉丝因为索尼在PS平台上线《原神》,怒而
  • 小米汽车电池信息疑似曝光:容量101kWh,支持800V高压快充

    7月14日消息,今日一名博主在社交媒体发布了一张疑似小米汽车电池信息的照片,显示该电池包正是宁德时代麒麟电池,容量为101kWh,电压为726.7V,可以预测小
  • 电博会与软博会实现"线下+云端"的双线融合

    在本次“电博会”与“软博会”双展会利好条件的加持下,既可以发挥展会拉动人流、信息流、资金流实现快速交互流动的作用,继而推动区域经济良性发展;又可以聚
Top