您的位置:首页 > 编程语言 > Java开发

quartz 和 spring的 线程池 ThreadPoolTaskExecutor 使用

2017-02-23 00:00 956 查看
在 一般的中小项目 使用 最多的是 quartz 定时任务,执行。就算没有线程池 也是可以 执行的。
但是 目前项目 中配置了 spring 线程池 。
而且 ThreadPoolTaskExecutor 线程池 也是可以 单独使用的。

如果 项目里面 一旦都配置了 线程池 和 quartz 的时候,就 晕了。有点蒙。。
上网百度了 一下 。
如果有了 线程池 ,那么 quartz 执行任务的时候, 取的线程 就是 线程 池里面定义的 线程的。
而且 线程池是有 一些地方是 很有帮助的,可以很好的 并发。而不让 任务或者是 程序 阻塞。
比如 2个 定时任务 A, B , 一个定时任务 A 执行的时间要得比较久, 但是 在 A 执行的时候 , 就要执行B 任务。 如果有线程池的话。 B就不会 阻塞 执行了。而且 对B 没有什么影响的。

如果是 单独 使用线程池的时候 , 比如 远程连接,需要 花费的时候比较长的时候 。就可以使用线程池 来 执行了。而不影响其他的 程序执行。 这就是 他们说的 并发。。

ThreadPoolTaskExecutor 配置

<bean id ="taskExecutor"
class="org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor" >
<property name ="corePoolSize" value ="5" />
<property name ="keepAliveSeconds" value ="300" />
<property name ="maxPoolSize" value ="10" />
<property name ="queueCapacity" value ="25" />
</bean>

属性字段说明:
corePoolSize: 线程池维护线程的最少数量
keepAliveSeconds 线程池维护线程所允许的空闲时间
maxPoolSize 线程池维护线程的最大数量
queueCapacity 线程池所使用的缓冲队列

使用 :

ApplicationContext ctx =  new
ClassPathXmlApplicationContext("applicationContext.xml");
ThreadPoolTaskExecutor poolTaskExecutor = (ThreadPoolTaskExecutor)
ctx.getBean("taskExecutor");

Thread udpThread = new Thread(udp);
poolTaskExecutor.execute(udpThread);
获取当前线程池活动的线程数:
int count = poolTaskExecutor.getActiveCount();
logger.debug("[x] - now threadpool active threads totalNum : " +count);

参考地址: https://my.oschina.net/52love/blog/713496
以及参考 地址: https://my.oschina.net/jgy/blog/472845

参考地址: http://blog.csdn.net/pzw_0612/article/details/48211417

如果需要有 返回值 : 地址: http://blog.csdn.net/lipc_/article/details/52786377

当然 ,也要看 情况了, 如果 远程连接 反应 比较快, 那么也是不需要 使用调用,线程池的。
具体看 情况了。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: