quartz 和 spring的 线程池 ThreadPoolTaskExecutor 使用
2017-02-23 00:00
956 查看
在 一般的中小项目 使用 最多的是 quartz 定时任务,执行。就算没有线程池 也是可以 执行的。
但是 目前项目 中配置了 spring 线程池 。
而且 ThreadPoolTaskExecutor 线程池 也是可以 单独使用的。
如果 项目里面 一旦都配置了 线程池 和 quartz 的时候,就 晕了。有点蒙。。
上网百度了 一下 。
如果有了 线程池 ,那么 quartz 执行任务的时候, 取的线程 就是 线程 池里面定义的 线程的。
而且 线程池是有 一些地方是 很有帮助的,可以很好的 并发。而不让 任务或者是 程序 阻塞。
比如 2个 定时任务 A, B , 一个定时任务 A 执行的时间要得比较久, 但是 在 A 执行的时候 , 就要执行B 任务。 如果有线程池的话。 B就不会 阻塞 执行了。而且 对B 没有什么影响的。
如果是 单独 使用线程池的时候 , 比如 远程连接,需要 花费的时候比较长的时候 。就可以使用线程池 来 执行了。而不影响其他的 程序执行。 这就是 他们说的 并发。。
使用 :
参考地址: 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
当然 ,也要看 情况了, 如果 远程连接 反应 比较快, 那么也是不需要 使用调用,线程池的。
具体看 情况了。
但是 目前项目 中配置了 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
当然 ,也要看 情况了, 如果 远程连接 反应 比较快, 那么也是不需要 使用调用,线程池的。
具体看 情况了。
相关文章推荐
- 使用SPRING中的线程池ThreadPoolTaskExecutor实现JAVA并发
- 使用Spring中的线程池ThreadPoolTaskExecutor实现JAVA并发
- Spring的线程池ThreadPoolTaskExecutor使用案例
- Spring教程____Spring线程池_ThreadPoolTaskExecutor的配置和使用
- 使用SPRING中的线程池ThreadPoolTaskExecutor实现并发
- 使用SPRING中的线程池ThreadPoolTaskExecutor并且得到任务执行的结果
- Spring线程池配置使用---ThreadPoolTaskExecutor 配置
- 使用SPRING中的线程池ThreadPoolTaskExecutor实现JAVA并发
- SPRING中的线程池ThreadPoolTaskExecutor
- SPRING中的线程池ThreadPoolTaskExecutor
- 使用Spring ThreadPoolTaskExecutor实现多线程任务
- SPRING中的线程池ThreadPoolTaskExecutor
- java 线程池(ExecutorService与Spring配置threadPoolTaskExecutor)
- Spring中的线程池ThreadPoolTaskExecutor
- SPRING中的线程池ThreadPoolTaskExecutor
- 利用spring的线程池ThreadPoolTaskExecutor对多个库进行数据归档
- SPRING中的线程池ThreadPoolTaskExecutor
- SPRING中的线程池ThreadPoolTaskExecutor
- 关于spring线程池ThreadPoolTaskExecutor的作用
- 通过线程池使用多线程并发:ThreadPoolTaskExecutor 的应用例子