当前位置: 首页 > news >正文

Spring Boot性能提升的核武器,速度提升500%!

虚拟线程是 Java 21 引入的一个新特性,用于简化并发编程。它与传统的操作系统线程相比,具有显著的优势:

  1. 轻量级:虚拟线程由 JVM 管理,而非操作系统,因此它们的内存占用和创建成本远低于传统线程。理论上,你可以轻松创建数十万甚至更多的虚拟线程。

  2. 高并发性:虚拟线程能处理更高并发的场景,特别是 I/O 密集型的应用,适合开发高并发、响应式的应用程序。

  3. 自动管理:无需手动管理线程池,JVM 会根据负载自动调整虚拟线程的调度,简化了并发编程的复杂性。

虚拟线程的基础用法

创建虚拟线程非常简单。你可以像创建传统线程一样启动虚拟线程,但它的创建与启动更加轻量:

Thread?virtualThread?=?Thread.ofVirtual().start(()?->?{
????System.out.println('虚拟线程正在运行');
});
System.out.println('主线程正在运行');

虚拟线程的延迟启动:

Thread?virtualThread?=?Thread.ofVirtual()
????.name('虚拟线程')
????.unstarted(()?->?System.out.println('虚拟线程运行中'));virtualThread.start();
virtualThread.join();?//?等待虚拟线程完成

在Spring Boot中使用虚拟线程

在 Spring Boot 项目中使用虚拟线程需要一些简单的配置:

图片

  1. 确保 Java 版本为 21 或以上。

  2. pom.xml 中启用 --enable-preview,以便支持虚拟线程特性。

    ????org.apache.maven.plugins ????maven-compiler-plugin ???? ????????21 ????????21 ???????? ????????????--enable-preview ???????? ????
  3. application.properties 中启用性能监控工具:

    management.endpoints.web.exposure.include=health,info,metrics

  4. 在 Spring Boot 中为 Tomcat 配置虚拟线程执行器:

    @Bean
    public?TomcatProtocolHandlerCustomizer<?>?protocolHandlerVirtualThreadExecutorCustomizer()?{
    ???return?protocolHandler?->?protocolHandler.setExecutor(Executors.newVirtualThreadPerTaskExecutor());
    }

实验:传统线程 vs 虚拟线程

1. 创建100,000个线程并执行

传统线程:

for?(int?i?=?0;?i?<?100_000;?i++)?{
????Thread?thread?=?new?Thread(()?->?System.out.println(i));
????thread.start();
????thread.join();
}

执行耗时约 18.6 秒。

虚拟线程:

for?(int?i?=?0;?i?<?100_000;?i++)?{
????Thread?thread?=?Thread.ofVirtual().unstarted(()?->?System.out.println(i));
????thread.start();
????thread.join();
}

执行耗时仅 3.7 秒,性能提升了近 500% 。

2. HTTP 请求性能对比

在高并发场景下,虚拟线程的优势尤为明显。我们对比了传统线程与虚拟线程在处理 HTTP 请求时的表现。

配置 HTTP 线程执行器:

@Bean
public?TomcatProtocolHandlerCustomizer<?>?protocolHandlerVirtualThreadExecutorCustomizer()?{
????return?protocolHandler?->?protocolHandler.setExecutor(Executors.newVirtualThreadPerTaskExecutor());
}

请求测试:发送 1600 个 HTTP 请求,400 并发。

  1. 传统线程:

    • 请求耗时:9.659 秒

    • 每秒请求数:165.65

  2. 虚拟线程:

    • 请求耗时:7.912 秒

    • 每秒请求数:202.22

虚拟线程的吞吐量大幅提升,响应时间显著缩短。

Java性能提升的其他技巧

除了虚拟线程,Java 还有一些其他的性能提升技巧,尤其适用于 Spring Boot 高并发场景:

  1. 使用并行流:对于 CPU 密集型任务,可以使用并行流(parallelStream())来利用多核 CPU,提高处理速度。

    List?numbers?=?Arrays.asList(1,?2,?3,?4,?5);
    numbers.parallelStream().forEach(number?->?{
    ???System.out.println(number?*?2);
    });

  2. 异步编程与CompletableFuture:对于 I/O 密集型任务,可以使用 CompletableFuture 进行异步处理,减少线程阻塞,提高响应性能。

    CompletableFuture?future?=?CompletableFuture.runAsync(()?->?{
    ???//?异步执行任务
    ???System.out.println(‘异步任务完成’);
    });
    future.join();??//?等待任务完成

  3. 优化数据库查询:减少数据库查询的次数,使用缓存(如 Redis)来存储频繁查询的数据,减少不必要的 I/O 操作。

  4. 内存管理优化:通过使用对象池(如 Apache Commons Pool)来管理资源,减少频繁的对象创建和销毁,提高内存使用效率。

小结

  1. 虚拟线程 是 Java 并发编程的革新,它简化了线程管理,提升了高并发场景下的性能。

  2. 使用虚拟线程,你可以轻松创建数十万甚至更多线程,而不会影响应用的性能。

  3. 在 Spring Boot 中配置虚拟线程非常简单,只需几行代码即可启用虚拟线程,带来显著的性能提升。

  4. 除了虚拟线程,其他优化技巧(如并行流、异步编程、数据库查询优化等)也能有效提升 Java 应用的性能。

通过这些技巧,Spring Boot 应用能够在高并发场景下表现出更强的性能和更低的响应延迟。

http://www.dtcms.com/a/605115.html

相关文章:

  • SOLIDWORKS 2025设计效率的大幅提高
  • 比标准Json库好用——json-iterator
  • 汇编语言编译器的作用 | 探讨汇编编译器的工作原理和实际应用
  • C语言编译器下载地址与安装指南
  • kanass实战教程系列(4) - 产品经理如何使用kanass有效管理需求
  • RLS(递归最小二乘)算法详解
  • 红色好看的网站济南网络推广软件公司
  • mvcc 简介
  • UniApp 商品分类左右联动技术文档
  • pytest 入门指南:Python 测试框架从零到一(2025 实战版)
  • SpringBoot教程(三十三)| SpringBoot集成MinIO
  • 【开题答辩全过程】以 基于.NET MVC的线上鞋服交易系统设计与实现为例,包含答辩的问题和答案
  • MySQL 全体系深度解析(存储引擎、事务、日志、MVCC、锁、索引、执行计划、复制、调优)
  • SpringMVC基础教程(1)--MVC/DispathcerServlet
  • 在streampark运行paimon-flink-action-1.20.0.jar
  • AI得贤面试智能体:重构企业招聘新范式
  • 硅基计划6.0 陆 JavaEE HttpHttps协议
  • 稳定边界层高度参数化方案的回归建模
  • 企业网站推广方法wap网站预览
  • 可以做推广的门户网站wordpress适合中国的小插件介绍
  • Dubbo服务治理全解析:从零搭建高可用微服务架构
  • java List怎么转换为Vector
  • 2023年辽宁省数学建模竞赛-B题 数据驱动的水下导航适配区分类预测-基于支持向量机对水下导航适配区分类的研究
  • 机器学习--KNN算法中的距离、范数、正则化
  • openGauss向量数据库功能实操测评:轻量部署下的高维检索能力
  • php做网站还是linuxseo服务外包费用
  • 《算法通关指南:算法基础篇 ---- 二维前缀和 — 1. 【模板】二维度前缀和,2.激光炸弹》
  • SpringBoot+openGauss DataVec构建高效RAG知识库实践
  • JVM 垃圾回收算法的详细介绍
  • 生成式引擎优化(GEO)实用指南(三):结构化内容与AI优化策略