quartz提供了基本的定时任务管理方法,与spring结合可以方便的使用定时任务。但quartz的弊端也显而易见,比如动态修改定时配置,定时任务的统一管理界面、调度和监控都是十分不便的。我们曾于quartz开发了定时任务的管理模块,主要针对定时任务的定时配置进行管理。技术总监徐总提出了使用easyschedule的方案,我们针对这一解决方案比较方便的解决了公司内部各信息系统的定时任务的管理和监控,以下是easySchedule的使用总结,比较简单,以下的代码实现方案主要是为了将原quartz的实现无缝的与easySchedule结合,涉及的主要是使用。明天会接接入,特别是小型web系统的接入方法做更详细的描述。
EasySchedule 是基于quartz的集群、分布式任务调度平台。广告技术部前端原有定时任务功能 相对比较简单,交互性差,任务部署效率低, 开发和维护成本高,不能很好满足各系统定时任务 的管理和控制; 大量Crontab触发的shell任务分散于各处系统,无法统一进 行管理,维护成本很高;许多任务都是单机部署,可用性差。
主要功能:
1.集群管理调度,分布式部署:保证系 统的高可用性、伸缩性、负载均衡。
2.友好的操作界面:通过控制台部署管 理任务,方便灵活高效。
3.任务持久化于数据库,远离宕机和数 据丢失隐患,完善的任务失败重做机制,及详细的任务跟踪及告警策略。
优点:
1Server和Client分别支持集群和分布式部署
2.任务的执行与调度分离
3.可视化管理所有任务
4.任务状态持久化于DB
5.完善的日志跟踪和告警策略
6.任务支持异步调度
7.灵活支持各种自定义任务,扩展方便。
1.1×××地址
下载地址:http://code.taobao.org/svn/easyschdeule/
1.2代码结构
EasySchedule它是一个maven项目 所以导入Maven项目 它的结构这这样的:
es-client:最终在打包的时候会生成一个jar包。这个将会被我们添加到我们自己的项目当中
es-server: 最终在打包时候会生成一个war包。这个需要我们部署到tomcat中 然后运行起来。
es-docs:里面存放一些文档和 建表语句和表数据内容。
使用 EasySchedule分为两点:
将es-client生成的jar包引入到我们自己的项目当中 (后面会作介绍)
将es-server生成的war部署成功
1.3 服务端部署
1.根据文档中的的建表语句创建表 并插入数据内容。
2.配置数据源
3.打开es-core项目下src/mian/resources下面的springbeans-es-ds.xml文件
4.在tomcat下面conf下面context.xml加上以下配置
<Resource name="jdbc/easyscheduleDataSource" auth="Container" type="javax.sql.DataSource" driverClassName="com.mysql.jdbc.Driver" url="jdbc:mysql://172.16.100.131:3307/test_crm" username="test_crm" password="test_crm" maxActive="20" maxIdle="10" maxWait="1000" />
5.更换jar包
将cglib-2.1_3.jar包更换成cglib-2.2.2.jar包
6.部署成功后可以访问 我们可以看到这样的页面
二、easyschedule的应用2.1 技术架构
2.2 功能简介
功能域:
2.3 任务执行流程
2.4标准任务及客户端代码实现
2.4.1添加
点击添加标准任务,首先填写任务属性
任务组一般指属于哪个应用,任务组的添加和配置参见参数管理。
再填写任务参数
每个任务参数的意义在右侧已经有很清晰的说明。默认可直接使用默认值,填写目标地址即可。
填写触发条件
触发条件支持简单按一定间隔时间执行的规则,也支持按不同时间频率的触发规则。
备注:简单类型的任务当执行次数为减为0的时候,该任务会被删除。
点击创建后,将在任务列表中出现该任务
可通过右侧做任务相关操作。
暂停:暂停该任务,EasySchedule将暂停该任务的调度。
立即执行:立即触发该任务。
修改:任务修改。
删除:任务删除。
详情:查看任务的详情。
历史:该任务历史记录,包含操作记录,执行记录,报警记录。
备注:所有操作都有相应的权限控制
2.4.2 接入
为了保证客户端的任务只被EasySchedule调度,需要在由于任务并非是只需要提供Http的URL即可,还需要在执行端做Token验证,保证只有ES能够调用到,所以需要对任务执行端进行一定程度的接入。
工程pom.xml增加依赖项(注意:es-client区分环境配置,开发和正式环境需要依赖不同的JAR包)
2.4.3OA接入事例
1. 代码部分
1. 编写代码实现类,代码通原来定时任务一致实现IJobTaskService 接口
public interface IJobTaskService { /** * 定时任务接口方法 * @author chao.gao * @date 2014-5-7 上午9:10:29 */ void execute(); }
2.在实现方法中编写定时任务处理逻辑
2.4.4 Spring配置
1. 配置实现类的Spring配置文件。
<bean id="processExecutionService" class="com.fx.oa.module.bpm.workflow.server.service.impl.ProcessExecutionService"/>
2. 配置 spring_quartz.xml 定时任务配置文件
<bean id="jobDelegate10" class="com.fx.platform.job.JobDelegate" scope="prototype"> <property name="serviceList"> <list> <ref bean="processExecutionService" /> </list> </property> </bean>
配置jobDelegate
2.4.5 配置定时任务项目
1. 新建对应的定时任务,
(1) targetUrl: 为定时任务请求 URL 地址为: http://OA地址/quartz/doJob.do
(2) Parameter : 为定时任务请求参数,其配置规则为: COMMAND_NAME=spring_quartz.xml 中配置的 jobDelegate .
2 .配置定时任务的定时时间
其配置的时间规则同 Spring的Quartz的配置规则相同。
如需要easySchedule的源码和相关jar包的可以联系我。