2007-06-17
Quartz 执行多线程任务
现在项目(web)中有个需求,每天临晨对一个 WEB 目标进行页面爬取,爬取过程是一个多线程任务,这个任务由 Quartz(Spring2 整合)cronTrigger 来调度。 大概同时会派出5-10个爬虫线程,执行爬虫线程的线程池,也是由 Spring 配置的 SimpleThreadPoolTaskExecutor。
现在的情况:众所周知,Quartz 缺省维持了一组自己的线程池,default pool size = 10。 实际上我全系统只有一个任务,每天运行一次,那么,每次调度触发时,池中始终只有一个线程会被用到。 这个线程开始执行任务后, 单独配置的爬虫线程池再接着开始执行爬取任务。
现在的问题:虽然 Spring 整合了 Quartz,但是 Quartz 线程池内的线程,依然工作在容器收管之外,本身就存在私立线程的风险。除此之外,系统还为爬虫线程另外配置了一个线程池(size也是10),资源风险进一步增加。 在不否决 Quartz 方案的前提下,怎么做才能将此风险最小化? 首先我能想到的,就是将 Quartz 的 default pool size 覆盖为 1,因为全系统始终只有一个例行任务,不需要那么大的任务线程池; 另外有一个假想, 我的10个爬虫线程,能不能就从 Quartz 自带的线程池里取,不再另外为爬虫线程专门配置一个池。 因为 Quartz 自己的线程池,实际上也是一个 SimpleThreadPoolTaskExecutor。 如果这个假想可行的话,那么,Quartz 自己的线程池,既用来执行任务本身,也负责爬虫线程的执行工作。
不知道有没有朋友做过这样的尝试,有的话请不吝赐教。
现在的情况:众所周知,Quartz 缺省维持了一组自己的线程池,default pool size = 10。 实际上我全系统只有一个任务,每天运行一次,那么,每次调度触发时,池中始终只有一个线程会被用到。 这个线程开始执行任务后, 单独配置的爬虫线程池再接着开始执行爬取任务。
现在的问题:虽然 Spring 整合了 Quartz,但是 Quartz 线程池内的线程,依然工作在容器收管之外,本身就存在私立线程的风险。除此之外,系统还为爬虫线程另外配置了一个线程池(size也是10),资源风险进一步增加。 在不否决 Quartz 方案的前提下,怎么做才能将此风险最小化? 首先我能想到的,就是将 Quartz 的 default pool size 覆盖为 1,因为全系统始终只有一个例行任务,不需要那么大的任务线程池; 另外有一个假想, 我的10个爬虫线程,能不能就从 Quartz 自带的线程池里取,不再另外为爬虫线程专门配置一个池。 因为 Quartz 自己的线程池,实际上也是一个 SimpleThreadPoolTaskExecutor。 如果这个假想可行的话,那么,Quartz 自己的线程池,既用来执行任务本身,也负责爬虫线程的执行工作。
不知道有没有朋友做过这样的尝试,有的话请不吝赐教。
- 浏览: 4411 次
- 来自: K星座

- 详细资料
搜索本博客
最近加入圈子
最新评论
-
SNA 架构下的在线人数统计
我们做的一个WEB系统,也有实时统计在线人数和具体人员的要求。我们采用主框架页A ...
-- by 雁行 -
SNA 架构下的在线人数统计
在线统计的计数自然是放到缓存里的。 我关心的问题是,怎样才能不依赖于 se ...
-- by totobacoo -
SNA 架构下的在线人数统计
dingyuan 写道既然都sna了。。在线统计的计数也放到缓存或者给数据库用户 ...
-- by hocus -
SNA 架构下的在线人数统计
既然都sna了。。在线统计的计数也放到缓存或者给数据库用户表加一个字段,标示用户 ...
-- by dingyuan -
Quartz 执行多线程任务
quartz 作为独立程序来运行,连我提的问题都不会存在了。 我想讨论的前提就是 ...
-- by totobacoo






评论排行榜