基于easySchedule的定时任务管理

一、easySchedule概述

       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项目 它的结构这这样的:

wKioL1bWsPzzcFu9AAAeZmCVxwE492.png

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文件

wKioL1bWsTqCzylpAABXaPH-pSI461.png


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.部署成功后可以访问 我们可以看到这样的页面

wKioL1bWscby0iHJAABjB6teKI0301.png

二、easyschedule的应用

2.1 技术架构

wKiom1bWsdHCMSbNAABcz4EBVjM724.png


2.2 功能简介

功能域:

wKiom1bWslTgM4MkAACMmfrqJq0093.png

2.3 任务执行流程

wKioL1bWsuHDrmPuAABvtICG0vo895.png

2.4标准任务及客户端代码实现

2.4.1添加

点击添加标准任务,首先填写任务属性


wKioL1bWsyPjCz4eAACeoRZOBO0907.png

任务组一般指属于哪个应用,任务组的添加和配置参见参数管理。

再填写任务参数

wKiom1bWsxKy31DSAABxOTJfJzw944.png

每个任务参数的意义在右侧已经有很清晰的说明。默认可直接使用默认值,填写目标地址即可。

填写触发条件

wKioL1bWs73RWG1CAAAgWIBCtTE332.png

触发条件支持简单按一定间隔时间执行的规则,也支持按不同时间频率的触发规则。

备注:简单类型的任务当执行次数为减为0的时候,该任务会被删除。

点击创建后,将在任务列表中出现该任务

wKioL1bWtDWyiOKmAAAdnM7bzfE668.png

可通过右侧做任务相关操作。

暂停:暂停该任务,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包的可以联系我。






     本文转自 gaochaojs 51CTO博客,原文链接:http://blog.51cto.com/jncumter/1746859,如需转载请自行联系原作者


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
为什么使用PHP管理crontab 一般在定时任务较少的情况下,使用原生的crontab服务一般不会有什么问题,但当定时任务较多时就会产生如下问题: 文本形式的定时任务可读性很差,在没有任何注释的情况下,新人很难在不读源码的情况下了解定时任务的业务逻辑 在分布式的场景中,定时任务会散落到多台机器上,无法统一管理 定时任务的日志不能集中化管理,对定时任务的运行分析及故障排除比较麻烦 基于以上几点原因,我们迫切的需要一个可以集中化管理的、可配置的定时任务管理器 但自己开发一套分布式的定时任务系统何其复杂,所以作者采用crontab服务做辅助,使用php实现对定时任务的配置管理 使用php管理定时任务有哪些优势 定时任务可以不再是以文本方式的形式存在,可以存储在缓冲、数据库中,甚至你可以开发管理功能,在后台对定时任务进行编辑 定时任务的日志是可配置的,你可以按照业务需求,对日志进行差异化配置 使用方式如下: 编写一个任务管理器,可参考test/simple.php 将上述脚本添加到crontab中,一分钟执行一次 示例: <?php $crontab_config = [  'test_1' => [  'name' => '服务监控1',  'cmd' => 'php -v',  'output' => '/tmp/test.log',  'time' => '* * * * *'  ],  'single_test' => [  'name' => 'php -i',  'cmd' => 'php -i',  'output' => '/tmp/single_script.log',  'time' => [  '* * * * *',  '* * * * *',  ],  ], ];  $crontab_server = new \Jenner\Zebra\Crontab\Crontab($crontab_config); $crontab_server->start(); 工具短小,但很精悍 在分布式场景中,你可以把定时任务写入数据库中进行统一管理,你可以设定哪些定时任务是由哪些机器执行, 然后通过生成文本文件的方式发送到所有机器上,再由这些机器上的phpCrontab读取处理;从而实现分布式场景下的定时任务统一管理。 标签:Zebra

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值