浏览 12225 次
锁定老帖子 主题:Quartz 执行多线程任务
精华帖 (0) :: 良好帖 (0) :: 新手帖 (0) :: 隐藏帖 (0)
|
|
---|---|
作者 | 正文 |
发表时间:2007-06-17
现在的情况:众所周知,Quartz 缺省维持了一组自己的线程池,default pool size = 10。 实际上我全系统只有一个任务,每天运行一次,那么,每次调度触发时,池中始终只有一个线程会被用到。 这个线程开始执行任务后, 单独配置的爬虫线程池再接着开始执行爬取任务。 现在的问题:虽然 Spring 整合了 Quartz,但是 Quartz 线程池内的线程,依然工作在容器收管之外,本身就存在私立线程的风险。除此之外,系统还为爬虫线程另外配置了一个线程池(size也是10),资源风险进一步增加。 在不否决 Quartz 方案的前提下,怎么做才能将此风险最小化? 首先我能想到的,就是将 Quartz 的 default pool size 覆盖为 1,因为全系统始终只有一个例行任务,不需要那么大的任务线程池; 另外有一个假想, 我的10个爬虫线程,能不能就从 Quartz 自带的线程池里取,不再另外为爬虫线程专门配置一个池。 因为 Quartz 自己的线程池,实际上也是一个 SimpleThreadPoolTaskExecutor。 如果这个假想可行的话,那么,Quartz 自己的线程池,既用来执行任务本身,也负责爬虫线程的执行工作。 不知道有没有朋友做过这样的尝试,有的话请不吝赐教。 声明:ITeye文章版权属于作者,受法律保护。没有作者书面许可不得转载。
推荐链接
|
|
返回顶楼 | |
发表时间:2007-06-17
robbin 有篇专门讲这个问题的文章,就是把quartz作为一个独立的进程使用。可以搜下,关键字 quartz
|
|
返回顶楼 | |
发表时间:2007-06-17
quartz 作为独立程序来运行,连我提的问题都不会存在了。 我想讨论的前提就是在容器环境下。 Quartz 也许是有资源风险的问题,但是就算作为独立程序来运行,如果程序设计不当的话,同样也可能产生新的资源风险。 在现有方案不能大改的情况下,我更关心如何复用线程池,将风险最小化 |
|
返回顶楼 | |