文章目录

  • 0.环境说明
  • 1.原理解析
  • 2.spring boot的方案
  • 3.注意事项(施工中,欢迎补充)

前置知识

  • 虚拟线程VT(Virtual Thread)

0.环境说明

用于验证的版本:

  • spring boot: 3.3.3
  • jdk: OpenJDK 21.0.5

spring boot 3.1中就支持使用jdk21的虚拟线程了,但是在spring boot 3.2中可以直接通过配置的方式开启虚拟线程。不过本文编写的时候spring boot 3.3.3已经GA了,他在3.2的基础上又对虚拟线程进行了进一步地适配,所以本文章中的版本为3.3

在spring boot 3.2.9中配置spring.threads.virtual.enabled=true即可启用虚拟线程

1.原理解析

开启了这个配置后,对我们的spring boot服务有什么影响呢?

我们在spring boot的源码中搜索spring.threads.virtual.enabled即可看到这个配置在spring boot中生效在了什么地方。
首先我们可以看到如下的代码(通过代码注释也能看出,这个配置就是在3.2.0引入的)

/*** Threading of the application.** @author Moritz Halbritter* @since 3.2.0*/
public enum Threading {/*** Platform threads. Active if virtual threads are not active.*/PLATFORM {@Overridepublic boolean isActive(Environment environment) {return !VIRTUAL.isActive(environment);}},/*** Virtual threads. Active if {@code spring.threads.virtual.enabled} is {@code true}* and running on Java 21 or later.*/VIRTUAL {@Overridepublic boolean isActive(Environment environment) {return environment.getProperty("spring.threads.virtual.enabled", boolean.class, false)&& JavaVersion.getJavaVersion().isEqualOrNewerThan(JavaVersion.TWENTY_ONE);}};/*** Determines whether the threading is active.* @param environment the environment* @return whether the threading is active*/public abstract boolean isActive(Environment environment);}

接下来我们看一下VIRTUAL.isActive(environment)这个方法都用在了哪里(哪里用到了,就说明哪里的虚拟线程是通过这个配置生效的)

可以看到他被用在如下的地方:

  • spring-webflux(区别于spring web的一个响应式web开发框架)的阻塞配置中(如果阻塞了使用什么类型的线程去进行阻塞)
  • 注解ConditionalOnThreading的判断条件OnThreadingCondition
    • Rabbit MQ——一个消息队列,启用虚拟线程则执行configurer.setTaskExecutor(new VirtualThreadTaskExecutor("rabbit-direct-"));configurer.setTaskExecutor(new VirtualThreadTaskExecutor("rabbit-simple-"));
    • JedisConnection——一个redis客户端,启用虚拟线程则执行
      	SimpleAsyncTaskExecutor executor = new SimpleAsyncTaskExecutor("redis-");executor.setVirtualThreads(true);factory.setExecutor(executor);
      
    • LettuceConnection——一个redis客户端,启用虚拟线程则执行和Jedis类似的代码,都是把Executor设置为一个启用了虚拟线程的new SimpleAsyncTaskExecutor("redis-");
    • Kafka——一个消息队列,启用虚拟线程则执行和Jedis类似的两码,把Executor设置为一个启用了虚拟线程的new SimpleAsyncTaskExecutor("kafka-");
    • TaskExecutorConfigurations——spring boot中的任务调度器配置类,@Async(异步任务注解)所注解的方法会根据配置决定是用平台线程执行还是虚拟线程执行
    • TaskSchedulingConfigurations——spring boot中定时任务配置类,@Scheduled(定时任务注解)所注解的方法会根据配置决定是用平台线程执行还是虚拟线程执行
    • EmbeddedWebServerFactoryCustomizerAutoConfiguration——通常我们最关心的地方,这里定义了spring web的默认容器tomcat的线程配置(Jetty的工作线程配置也在一起),如果开启了虚拟线程,则tomcat会使用虚拟线程作为执行器(再也不用考虑tomcat默认200线程的问题了!!!)
  • Pulsar:一个分布式消息流平台,启用虚拟线程则执行containerProperties.setConsumerTaskExecutor(new VirtualThreadTaskExecutor("pulsar-consumer-"));readerContainerProperties.setReaderTaskExecutor(new VirtualThreadTaskExecutor("pulsar-reader-"));

2.spring boot的方案

通过在spring boot的源码搜索@ConditionalOnThreading(Threading.VIRTUAL),可以看到spring boot会根据虚拟线程的开启与否来选择注入不同的bean,我们以spring-data-redis为例,其具体代码如下:

    @Bean@ConditionalOnMissingBean(RedisConnectionFactory.class)@ConditionalOnThreading(Threading.PLATFORM)LettuceConnectionFactory redisConnectionFactory(ObjectProvider<LettuceClientConfigurationBuilderCustomizer> builderCustomizers,ClientResources clientResources) {return createConnectionFactory(builderCustomizers, clientResources);}@Bean@ConditionalOnMissingBean(RedisConnectionFactory.class)@ConditionalOnThreading(Threading.VIRTUAL)LettuceConnectionFactory redisConnectionFactoryVirtualThreads(ObjectProvider<LettuceClientConfigurationBuilderCustomizer> builderCustomizers,ClientResources clientResources) {LettuceConnectionFactory factory = createConnectionFactory(builderCustomizers, clientResources);SimpleAsyncTaskExecutor executor = new SimpleAsyncTaskExecutor("redis-");executor.setVirtualThreads(true);factory.setExecutor(executor);return factory;}

通过代码不难看出,spring boot 3.2通过@ConditionalOnThreading注解的方式,实现了虚拟线程和平台线程的动态配置。

如果我们自己需要开发一个能够同时支持平台线程和虚拟线程的sdk,可以复用这个注解。

3.注意事项(施工中,欢迎补充)

  • 使用虚拟线程本身要注意的5个点:
    1. 大方使用“一个请求一个线程”的开发方式
    2. 不需要对虚拟线程进行池化
    3. 使用信号量控制并发
    4. 慎用ThreadLocal,使用ScopeValue(java21中还是预览状态)代替
    5. 使用ReturnLock替代synchronized(这个问题似乎在jdk23中会永久解决)
  • java21默认的垃圾回收器G1和其自身的JIT编译器C2似乎有冲突,会导致jvm crash?(这里不能确定,似乎在高版本jdk 21.0.7中进行了修复,但是我比较了openjdk的源码,并没能找到具体的改动指向这个问题)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/pingmian/87771.shtml
繁体地址,请注明出处:http://hk.pswp.cn/pingmian/87771.shtml
英文地址,请注明出处:http://en.pswp.cn/pingmian/87771.shtml

如若内容造成侵权/违法违规/事实不符,请联系英文站点网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

利器:NPM和YARN及其他

文章目录**1. 安装 Yarn&#xff08;推荐方法&#xff09;****2. 验证安装****3. 常见问题及解决方法****① 权限不足&#xff08;Error: EPERM&#xff09;****② 网络问题&#xff08;连接超时或下载失败&#xff09;****③ 环境变量未正确配置****4. 替代安装方法&#xff0…

跨平台直播美颜SDK集成实录:Android/iOS如何适配贴纸功能

众所周知&#xff0c;直播平台与短视频平台的贴纸功能不仅是用户表达个性的方式&#xff0c;更是平台提高用户粘性和互动转化的法宝。 可问题来了&#xff1a;如何让一个贴纸功能&#xff0c;在Android和iOS两大平台上表现一致、运行流畅、加载稳定&#xff1f;这背后&#xff…

JavaWeb(苍穹外卖)--学习笔记04(前端:HTML,CSS,JavaScript)

前言 本片文章是学习B站黑马程序员苍穹外卖的学习笔记。因为最近期末周&#xff0c;一直在应付考试所以就学的很少&#xff0c;恰好视频中在讲Nginx反向代理和负载均衡&#xff08;写着对前端的内容做一个复习&#xff09; 概述&#xff1a; 1.web前端主要由三部分组成&…

智能学号抽取系统 V5.4.3.2 —— Vue.js 实现的多功能课堂随机抽签工具

智能学号抽取系统 V5.4.3.2 —— Vue.js 实现的多功能课堂随机抽签工具 在教学或会议场景中&#xff0c;我们经常需要随机抽取一个或多个学号/编号来决定发言者、答题者或者参与者。为了提高效率和公平性&#xff0c;我们可以使用一些智能化的小工具来实现这一过程。 今天介绍…

从0开始学习R语言--Day39--Spearman 秩相关

在非参数统计中&#xff0c;不看数据的实际数值&#xff0c;单纯比较两组变量的值的排名是通用的基本方法&#xff0c;但在客观数据中&#xff0c;很多变量的关系都是非线性的&#xff0c;其他的方法不是对样本数据的大小和线性有要求&#xff0c;就是只能对比数据的差异性&…

WSL - Linux 安装 Anaconda3-2025.06-0 详细教程 [WSL 分发版均适用]

一、检查系统状态 安装前先确认 WSL - Linxu 已正常启动&#xff08;比如 Ubuntu&#xff09;&#xff0c;网络连接稳定&#xff0c;并且系统磁盘有足够空间&#xff0c;一般建议预留至少 5GB 以上的可用空间&#xff0c;避免因空间不足导致安装失败。 二、下载安装包 Anacond…

热血三国建筑攻略表格

<!DOCTYPE html> <html lang"zh-CN"><head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0"><title>热血三国建筑攻略表格</title><style>…

SpringBoot+MySQL医院挂号系统源码

概述 基于SpringBootMySQL开发的医院挂号系统完整源码&#xff0c;该系统功能完善&#xff0c;包含从患者挂号到医生管理的全流程解决方案&#xff0c;采用主流技术栈开发&#xff0c;代码规范易于二次开发。 主要内容 系统包含完整的前后台功能模块&#xff1a; ​​前台功…

Linux系统之MySQL数据库基础

目录 一、概述 数据库概念 数据库的类型 关系型数据库模型 关系数据库相关概念 二、安装 1、mariadb安装 2、mysql安装 3、启动并开机自启 4、本地连接&#xff08;本地登录&#xff09; 三、mysqld数据库配置与命令 yum安装后生成的目录 mysqld服务器的启动脚本 …

MySQL--InnoDB存储引擎--页结构

目录 一、页的大小 二、页的分类 三、页头和页尾 3.1 页头--File Header 3.2 页尾--File Trailer 3.3 LSN 四、数据行 五、页中数据的查询 六、事务和索引在页中的记录 一、页的大小 前面介绍了每个数据页默认大小为16KB&#xff0c;是操作系统“数据块” 4KB 的整数倍…

卡车检测数据集-700张图片交通运输管理 智能监控系统 道路安全监测

跌倒检测数据集-4500张图片&#x1f4e6; 已发布目标检测数据集合集&#xff08;持续更新&#xff09;&#x1f69b; Deteccin de carpa 2 Computer Vision Project&#x1f4cc; 数据集概览包含类别&#x1f3af; 应用场景&#x1f5bc; 数据样本展示&#x1f527; 使用建议&a…

Python爬虫实战:研究pangu库相关技术

1. 引言 1.1 研究背景与意义 在数字化信息传播时代,中文文本排版质量直接影响信息传达效果。规范的排版要求中文与西文、数字间保持合理空格间距,但人工处理不仅效率低,且易出现一致性问题。随着互联网中文内容爆发式增长,传统人工排版已无法满足需求。Python 作为高效的…

day48-考试系统项目集群部署

1. ✅考试系统项目集群架构图负载均衡说明7层负载通过nginx对http请求进行转发&#xff08;uri,ua,类型&#xff09;4层负载对端口负载均衡&#xff08;后端&#xff09;2. &#x1f4dd;环境准备角色主机ip负载均衡lb01/lb02172.16.1.5/172.16.1.6前端web集群web01/web02172.1…

Redis+Caffeine双层缓存策略对比与实践指南

RedisCaffeine双层缓存策略对比与实践指南在高并发场景下&#xff0c;缓存是提升系统性能和并发处理能力的关键手段。常见的缓存方案包括远程缓存&#xff08;如Redis&#xff09;和本地缓存&#xff08;如Caffeine&#xff09;。单层缓存各有优劣&#xff0c;结合两者优势的双…

FastAPI+React19 ERP系统实战 第02期

一、搭建环境 1.1 创建Python虚拟环境 切换Python版本: pyenv local 3.12创建虚拟环境: python -m venv venv激活虚拟环境: venv\Scripts\activate1.2 安装FastAPI项目依赖 requirements.txt fastapi==0.109.1

百度AI文心大模型4.5系列开源模型评测,从安装部署到应用体验

2025年6月30日&#xff0c;百度突然宣布&#xff0c;将旗下最新的大语言模型文心大模型4.5&#xff08;ERNIE 4.5&#xff09;全系列开源&#xff0c;震动整个AI行业。百度在GitCode平台上开源了文心大模型4.5系列&#xff0c;包括ERNIE-4.5-VL-424B-A47B-Base-PT等多个型号。此…

windows安装maven环境

在maven官网下载安装包 https://maven.apache.org/download.cgi 下载完成后安装maven&#xff0c;一般下载编辑好的 创建个maven目录解压出来即可 配置环境变量 根据刚刚的安装路径&#xff0c;新建一个命名为MAVEN_HOME的系统变量 新建完成点开系统变量的Path项&#xff0c;…

MySQL(117)何进行数据库安全加密?

数据库安全加密是保护敏感数据免受未授权访问的重要手段。以下是一个详细深入的步骤&#xff0c;介绍如何进行数据库安全加密&#xff0c;包括数据传输加密和数据存储加密。 一. 数据传输加密 确保数据在传输过程中被加密&#xff0c;以防止中间人攻击。我们以MySQL为例&#x…

工程化实践——标准化Eslint、PrettierTS

前端工程化中的标准化工具&#xff08;如Prettier、ESLint、Husky等&#xff09;虽然大幅提升了开发效率和代码质量&#xff0c;但在实际使用中也存在一些限制和挑战。以下从工具特性、团队协作、开发体验等维度详细分析常见限制&#xff0c;并以Prettier为核心举例说明&#x…

应急响应靶场——web3 ——知攻善防实验室

前景需要&#xff1a; 小苕在省护值守中&#xff0c;在灵机一动情况下把设备停掉了&#xff0c;甲方问&#xff1a;为什么要停设备&#xff1f;小苕说&#xff1a;我第六感告诉我&#xff0c;这机器可能被黑了。这是他的服务器&#xff0c;请你找出以下内容作为通关条件&#…