首页 > 代码库 > Spring 定时器结合线程池
Spring 定时器结合线程池
需求:Spring 定时器结合线程池处理工单
a.定时扫库查出一定数量的需要处理的工单
b.开启线程处理查出的工单
1,创建处理工单的task
@Component("AppWorkOrderTask")@Scope("prototype")public class AppWorkOrderTask implements Runnable { public static final String BEAN_NAME = "AppWorkOrderTask"; @Resource private IAppWorkOrderService appWorkOrderService; private String appWorkOrderId; public void execute() { //处理工单逻辑代码 } public String getAppWorkOrderId() { return appWorkOrderId; } public void setAppWorkOrderId(String appWorkOrderId) { this.appWorkOrderId = appWorkOrderId; } @Override public void run() { execute(); }}
2,创建扫库的定时器
public class AppWorkOrderScheduler extends TimerTask { private Logger logger = Logger.getLogger(AppWorkOrderScheduler.class); @Resource private IAppWorkOrderService appWorkOrderService; @Resource(name = "appWorkOrderTaskExecutor") private ThreadPoolTaskExecutor taskExecutor; @Override public void run() { //判断线程池容量 int size = taskExecutor.getMaxPoolSize() - taskExecutor.getActiveCount(); if (size > 0) {
//找出工单 List<String> appWorkOrderIds = appWorkOrderService.getAppWorkOrderList(20); logger.info("Find " + appWorkOrderIds.size() + " task(s) to execute..."); for (String appWorkOrderId : appWorkOrderIds) { AppWorkOrderTask task = newTask(appWorkOrderId); taskExecutor.execute(task); } } } private AppWorkOrderTask newTask(String appWorkOrderId) { AppWorkOrderTask task = (AppWorkOrderTask) BeanFactory.getInstance().getBeanByName(AppWorkOrderTask.BEAN_NAME);
//从applicationContext 中获取 appWorkOrderTask 公共类就不再贴了 task.setAppWorkOrderId(appWorkOrderId); return task; }}
3.配置文件
<?xml version="1.0" encoding="UTF-8"?><beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:aop="http://www.springframework.org/schema/aop" xmlns:tx="http://www.springframework.org/schema/tx" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-2.0.xsd http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-2.0.xsd http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-2.0.xsd" default-autowire="byName" default-lazy-init="true"> <!--应用工单异步线程执行器--> <bean id="appWorkOrderTaskExecutor" class="org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor"> <!-- 线程池维护线程的最少数量 --> <property name="corePoolSize" value="10"/> <!-- 线程池维护线程的最大数量 --> <property name="maxPoolSize" value="20"/> <!-- 线程池所使用的缓冲队列 --> <property name="queueCapacity" value="20" /> </bean> <bean class="org.springframework.scheduling.timer.TimerFactoryBean" lazy-init="false"> <property name="scheduledTimerTasks"> <list> <ref bean="appWorkOrderScheduledTimerTask" /> </list> </property> </bean> <!-- Application WorkOrder Scheduler Timer --> <bean id="appWorkOrderSchedulerTask" class="com.test.timer.scheduler.AppWorkOrderScheduler" /> <bean id="appWorkOrderScheduledTimerTask" class="org.springframework.scheduling.timer.ScheduledTimerTask"> <!-- 运行过程中延时10000ms(10s) --> <property name="delay" value="10000" /> <!-- 每隔90s运行一次 --> <property name="period" value="90000" /> <property name="timerTask" ref="appWorkOrderSchedulerTask" /> </bean></beans>
Spring 定时器结合线程池
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。