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

ops/2025/1/15 18:03:29/

虚拟线程是 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,以便支持虚拟线程特性。

<plugin><groupId>org.apache.maven.plugins</groupId><artifactId>maven-compiler-plugin</artifactId><configuration><source>21</source><target>21</target><compilerArgs><arg>--enable-preview</arg></compilerArgs></configuration>
</plugin>
  1. application.properties 中启用性能监控工具:

management.endpoints.web.exposure.include=health,info,metrics
  1. 在 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<Integer> numbers = Arrays.asList(1, 2, 3, 4, 5);
numbers.parallelStream().forEach(number -> {System.out.println(number * 2);
});
  1. 异步编程与CompletableFuture:对于 I/O 密集型任务,可以使用 CompletableFuture 进行异步处理,减少线程阻塞,提高响应性能。

CompletableFuture<Void> future = CompletableFuture.runAsync(() -> {// 异步执行任务System.out.println('异步任务完成');
});
future.join();  // 等待任务完成
  1. 优化数据库查询:减少数据库查询的次数,使用缓存(如 Redis)来存储频繁查询的数据,减少不必要的 I/O 操作。

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

小结

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

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

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

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

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


http://www.ppmy.cn/ops/150355.html

相关文章

后端接口获取的对象包含图片,渲染后端图片,拼接地址渲染,循环列表,vue+uniapp

如果是全链接的好说&#xff0c;直接item.img就行&#xff0c; <image :src"item.icon" ></image> 如果是加背景就是:style"[{backgroundImage:url(item.img)}]" 另外一种就是后端返回文件名字或者一部分链接&#xff0c;前面需要拼接上…

matlab使用 BP 神经网络进行数据预测的完整流程,包括数据读取、数据预处理等等

%% 初始化程序 warning off % 关闭报警信息 close all % 关闭所有图窗 clear % 清空变量 clc % 清空命令行 setdemorandstream(172) %设置随机种子为1%% 读取数据 data xlsread(Y.xlsx); %% 划分训练集…

朝天椒USB服务器在万家基金的前置机应用案例

随着云计算和大数据技术的快速发展&#xff0c;万家基金管理有限公司对数据中心的性能、可靠性和可扩展性提出了更高的要求。在这样的背景下&#xff0c;万家基金选择了超融合虚拟化技术作为其数据中心的核心技术&#xff0c;旨在通过虚拟化技术实现资源的按需分配和弹性扩展&a…

Python爬虫-汽车之家各车系周销量榜数据

前言 本文是该专栏的第43篇,后面会持续分享python爬虫干货知识,记得关注。 在本专栏之前,笔者在文章《Python爬虫-汽车之家各车系月销量榜数据》中,有详细介绍,如何爬取“各车系车型的月销量榜单数据”的方法以及完整代码教学教程。 而本文,笔者同样以汽车之家平台为例,…

TCP/UDP/IP报文大小

TCP/UDP/IP报文大小 1、概述 首先要看TCP/IP协议&#xff0c;涉及到四层&#xff1a;链路层&#xff0c;网络层&#xff0c;传输层&#xff0c;应用层。其中以太网&#xff08;Ethernet&#xff09;的数据帧在链路层 IP包在网络层 TCP或UDP包在传输层 TCP或UDP中的数据&…

是德科技Keysight N9020A实时频谱分析仪N9000A

是德科技Keysight N9020A实时频谱分析仪N9000A 是德科技N9020A实时频谱分析仪体验实时频谱分析 – 是德科技测量之道 PXA 和 MXA 是可通过升级添加 实时分析功能的主流信号分析仪。现 有的分析仪无需经过重新校准即可添 加实时分析功能。在 PXA 或 MXA 的 基础上&#xff0c…

采用GPT生成的Python 的 2048 游戏

采用GPT生成的Python 的 2048 游戏 文章说明核心代码效果展示源码下载 文章说明 采用GPT生成的一个小工具&#xff0c;作为一个python开发小游戏的demo&#xff0c;打发时间的小代码&#xff0c;后续可以考虑继续利用GPT生成更多有趣的小游戏 核心代码 2048小游戏-1.0版本 impo…

C++ 鼠标轨迹算法 - 防止游戏检测

一.简介 鼠标轨迹算法是一种模拟人类鼠标操作的程序&#xff0c;它能够模拟出自然而真实的鼠标移动路径。 鼠标轨迹算法的底层实现采用C/C语言&#xff0c;原因在于C/C提供了高性能的执行能力和直接访问操作系统底层资源的能力。 鼠标轨迹算法具有以下优势&#xff1a; 模拟…