java 开启异步 异步注解 @Async使用和遇到的问题总结

需求:项目中有个需求需要异步完成。

解决办法:问度娘,

1.需要配合启动类注解 @EnableAsync 使用

2.实现类的serviceImpl中增加@Lazy注解

3.在实现类中对应的方法增加@Async注解。

按照度娘搜到的内容完成以上步骤后启动,报循环引用错误。继续排查,从conttroller到service仔细看代码,发现问题。

原因:Service extends 继承了其他的service导致。

尝试解决办法:重新写一个新的service类来完成。

本地数据少,很快运行完,没有发现问题,客户现场数据量大,运行了40分钟左右,突然停掉了,也没有报错日志,请教大佬后,怀疑是运行时间过长,超时导致。

 spring.task.execution.pool.core-size:线程池创建时的初始化线程数,默认为8
 spring.task.execution.pool.max-size:线程池的最大线程数,默认为int最大值
 spring.task.execution.pool.queue-capacity:用来缓冲执行任务的队列,默认为int最大值
 spring.task.execution.pool.keep-alive:线程终止前允许保持空闲的时间
 spring.task.execution.pool.allow-core-thread-timeout:是否允许核心线程超时
 spring.task.execution.shutdown.await-termination:是否等待剩余任务完成后才关闭应用
 spring.task.execution.shutdown.await-termination-period:等待剩余任务完成的最大时间
 spring.task.execution.thread-name-prefix:线程名的前缀,设置好了之后可以方便我们在日志中查看处理任务

spring.task.execution.pool.allow-core-thread-timeout:false,在配置文件中增加了配置,最终解决。

总结:

如果@Async在方法上注解,是单线程运行

如果@Async在方法中的for循环内的方法中注解,是多线程运行(此方法也需要在service中存在,是接口,因为要被spring托管)。并且要配置最大线程数,否则for循环多少次就会生成多少个线程,最大数是int的max值,会内存溢出。

你可能感兴趣的:(java,开发语言)