Springboo3中使用虚线程

Java中的虚线程类似Go中的协程,简单来说可以通过同步编程的方式来达到异步编程模式的效果,具体的技术细节可以参考
https://blog.csdn.net/nyzzht123/article/details/132270674
https://openjdk.org/jeps/444

基础环境

虚线程最早在JDK19中推出,但是是preview的状态,正式版本是在JDK21中推出,如果你需要体验虚线程,可以在pom中进行如下配置

		<plugin>
				<groupId>org.apache.maven.plugins</groupId>
				<artifactId>maven-compiler-plugin</artifactId>
				<configuration>
					<source>21</source>
					<target>21</target>
				</configuration>
			</plugin>

如果你当前版本低于21,大于等于19,需要增加 --enable-preview参数来启动preview的功能

		<plugin>
            <groupId>org.apache.maven.plugins</groupId>
            <artifactId>maven-compiler-plugin</artifactId>
            <configuration>
                <source>19</source>
                <target>19</target>
                <compilerArgs>
                    --enable-preview
                </compilerArgs>
            </configuration>
        </plugin>

线程池配置

我们在web应用中常用的线程池有两类,一类是tomcat的线程池,另一类是后台异步任务的线程池,可以通过以下方式来创建


@Bean(TaskExecutionAutoConfiguration.APPLICATION_TASK_EXECUTOR_BEAN_NAME)
public AsyncTaskExecutor asyncTaskExecutor() {
  return new TaskExecutorAdapter(Executors.newVirtualThreadPerTaskExecutor());
}

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

需要注意的是,因为虚线程不是真正的OS线程,它的创建和销毁的成本很低,因此并不需要复用,线程池的创建也就不需要指定coreThread, maxThread这些参数(具体细节可以参考虚线程简介

日志输出

另外,除非在创建时指定,虚线程也没有名字,通过Thread#getName的方式只能获取到一个空字符串,在日志打印中,有可能会获取不到。对于不同的日志组件有不同的解决方案

  • 对于logback,需要将logback的版本升级到1.5.0以上
  • 对于log4j2,可以通过打印tid的方式来解决

相关推荐

  1. Springboo3使用虚线

    2024-07-20 15:16:02       26 阅读
  2. SpringBoot 3.2.1使用JPA报错

    2024-07-20 15:16:02       68 阅读
  3. SpringBoot3使用Swagger

    2024-07-20 15:16:02       34 阅读
  4. springBoot使用threadPoolTaskExecutor多线

    2024-07-20 15:16:02       56 阅读
  5. ElasticSeach--springboot使用

    2024-07-20 15:16:02       61 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-07-20 15:16:02       123 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-07-20 15:16:02       131 阅读
  3. 在Django里面运行非项目文件

    2024-07-20 15:16:02       109 阅读
  4. Python语言-面向对象

    2024-07-20 15:16:02       117 阅读

热门阅读

  1. C#面:MVC中的TempData\ViewBag\ViewData区别?

    2024-07-20 15:16:02       25 阅读
  2. Linux下载网络文档

    2024-07-20 15:16:02       23 阅读
  3. 网络爬虫基础介绍

    2024-07-20 15:16:02       27 阅读
  4. Linux内存从0到1学习笔记(8.20 ION (二))

    2024-07-20 15:16:02       26 阅读
  5. 基于 Go1.19 的站点模板爬虫:构建与实战

    2024-07-20 15:16:02       28 阅读
  6. Redis

    Redis

    2024-07-20 15:16:02      26 阅读
  7. 订单管理系统需求规范

    2024-07-20 15:16:02       32 阅读
  8. E15.【C语言】练习:逗号表达式和前置后置++

    2024-07-20 15:16:02       27 阅读