你知道 @Async 是怎么让方法异步执行的吗?
转载请申明出处
在阅读本文之前,你可以通过 Creating Asynchronous Methods 指导来体验下创建异步方法的使用方式。
为什么要写这篇文章,本质上对于这些 Spring 已经封装好的能力,并不需要去关注它底层到底是怎么玩的,比如 @Async
,你肯定可以猜到对于打了这个注解的方法(或者类),在执行这个方法(或者类下所有方法)时,Spring 框架会将当前方法丢进到一个单独的线程池中去执行,以达到方法异步执行的目的。
本篇文章的原始诉求来自于需要对 @Async
描述的方法进行 trace 埋点,当前大多数基于线程上下文传递 traceContext 的方式显然对于跨线程问题是不能满足的,需要特殊的处理;那么就需要对这些技术点进行剖析,以寻求切入点。
前言
@Async
是通过注解标记来开启方法的异步执行的;对于注解的底层实现,除了 java 原生提供那种依赖编译期植入的之外,其他的基本都差不多,即运行时通过反射等方式拦截到打了注解的类或者方法,然后执行时进行横切拦截;另外这里还有一个点就是方法异步执行,所以对于 @Async
的剖析,就一定绕不开两个基本的知识点,就是代理和线程池。
在了解到这些之后,我们来拆解下 @Async
的基本原理。