最近做了一个小项目,使用了异步任务+redis 存储用户登录和用户操作状态,开发测试的时候都没有问题,上线使用之后,一直看不到redis有数据,反复重装了几次redis,最后发现问题不在redis,最后查了日志发现报错如下,原来是部署的时候项目配置没改动!!!
报错信息
exception:
org.springframework.core.task.TaskRejectedException:
Executor [java.util.concurrent.ThreadPoolExecutor
did not accept task: org.springframework.aop.interceptor.AsyncExecutionInterceptor
原本的配置信息
<task:annotation-driven executor="myExecutor" />
<task:executor id="myExecutor" pool-size="1"
queue-capacity="10000" keep-alive="60" />
异步任务的池子设置为1 !!! 导致大量用户登录产生的异步任务在排队,而且项目其他位置也有一些长时间的异步任务,所以一直被堵塞着。
解决办法
把池子调大点就可以了,因为那个服务器配置比较低,我设置 pool-size=“50-200” ,目前稳定运行,暂时没发现新的问题。