README.md 5.1 KB
Newer Older
X
xueli.xue 已提交
1
# 分布式任务调度平台xxl-job
X
init  
xueli.xue 已提交
2
github地址:https://github.com/xuxueli/xxl-job
X
init  
xueli.xue 已提交
3

X
init  
xueli.xue 已提交
4 5 6
git.osc地址:http://git.oschina.net/xuxueli0323/xxl-job

博客地址(内附使用教程):http://www.cnblogs.com/xuxueli/p/5021979.html
X
xueli.xue 已提交
7

X
xueli.xue 已提交
8
技术交流群(仅作技术交流):367260654    [![image](http://pub.idqqimg.com/wpa/images/group.png)](http://shang.qq.com/wpa/qunwpa?idkey=4686e3fe01118445c75673a66b4cc6b2c7ce0641528205b6f403c179062b0a52)
X
xueli.xue 已提交
9

X
xueli.xue 已提交
10
# 特点:集群任务调度管理
X
init  
xueli.xue 已提交
11 12 13 14 15 16 17 18
	1、简单:支持通过Web页面对任务进行CRUD操作,操作简单,一分钟上手;
	2、动态:支持动态修改任务状态,动态暂停/恢复任务,即时生效;
	3、服务HA:任务信息持久化到mysql中,Job服务天然支持集群,保证服务HA;
	4、任务HA:某台Job服务挂掉,任务会平滑分配给其他的某一台存活服务,即使所有服务挂掉,重启时或补偿执行丢失任务;
	5、一个任务只会在其中一台服务器上执行;
	6、任务串行执行;
	7、支持任务执行日志;
	8、支持自定义参数;
19
	9、支持任务失败次数超阈值邮件报警;
20
	10、支持在线查看,执行器详细日志;
21
	11、支持远程任务执行终止;
X
xueli.xue 已提交
22
	12、支持登录验证;
X
xueli.xue 已提交
23
	
X
xueli.xue 已提交
24
# 新版本 V1.1.x,特性【于V1.1.x版本,XXL-JOB正式应用于我司,内部定制别名为 “Ferrari”,新接入应用推荐使用最新版本V1.3.x】
X
xueli.xue 已提交
25 26 27 28 29 30 31 32
	1、简单:支持通过Web页面对任务进行CRUD操作,操作简单,一分钟上手;
	2、动态:支持动态修改任务状态,动态暂停/恢复任务,即时生效;
	3、服务HA:任务信息持久化到mysql中,Job服务天然支持集群,保证服务HA;
	4、任务HA:某台Job服务挂掉,任务会平滑分配给其他的某一台存活服务,即使所有服务挂掉,重启时或补偿执行丢失任务;
	5、一个任务只会在其中一台服务器上执行;
	6、任务串行执行;
	7、支持自定义参数;
	8、支持远程任务执行终止;
X
init  
xueli.xue 已提交
33

X
xueli.xue 已提交
34 35 36
# 新版本 V1.2.x,新特性
	1、支持任务分组;
	2、支持“本地任务”、“远程任务”;
X
xueli.xue 已提交
37 38 39
	3、底层通讯支持两种方式,Servlet方式 + JETTY方式;
	4、支持“任务日志”;
	5、支持“串行执行”,并行执行;
X
xueli.xue 已提交
40
	
X
init  
xueli.xue 已提交
41
	说明:V1.2版本将系统架构按功能拆分为:
X
xueli.xue 已提交
42 43 44
		调度模块(调度中心):负责管理调度信息,按照调度配置发出调度请求;
		执行模块(执行器):负责接收调度请求并执行任务逻辑;
		通讯模块:负责调度模块和任务模块之间的信息通讯;
X
init  
xueli.xue 已提交
45 46 47 48
	优点:
		解耦:任务模块提供任务接口,调度模块维护调度信息,业务相互独立;
		高扩展性;
		稳定性;
X
xueli.xue 已提交
49 50

# 新版本 V1.3.x,新特性
X
xueli.xue 已提交
51
	1、遗弃“本地任务”模式,推荐使用“远程任务”,易于系统解耦,任务对应的JobHander统称为“执行器”;
X
xueli.xue 已提交
52
	2、遗弃“servlet”方式底层系统通讯,推荐使用JETTY方式,调度+回调双向通讯,重构通讯逻辑;
X
xueli.xue 已提交
53 54 55 56 57 58
	3、UI交互优化:左侧菜单展开状态优化,菜单项选中状态优化,任务列表打开表格有压缩优化;
	4、【重要】“执行器”细分为:BEAN、GLUE两种开发模式,简介见下文:
	
		“执行器” 模式简介:
			BEAN模式执行器:每个执行器都是Spring的一个Bean实例,XXL-JOB通过注解@JobHander识别和调度执行器;
			GLUE模式执行器:每个执行器对应一段代码,在线Web编辑和维护,动态编译生效,执行器负责加载GLUE代码和执行;
X
xueli.xue 已提交
59 60 61 62 63 64 65 66 67 68
			
# 新版本V1.3.1
	1、更新项目目录结构:
		/xxl-job-admin -------------------- 【调度中心】:负责管理调度信息,按照调度配置发出调度请求;
		/xxl-job-core ----------------------- 公共依赖
		/xxl-job-executor-example ------ 【执行器】:负责接收调度请求并执行任务逻辑;
		/db ---------------------------------- 建表脚本
		/doc --------------------------------- 用户手册
	2、在新的目录结构上,升级了用户手册;
	3、优化了一些交互和UI;
X
xueli.xue 已提交
69 70 71 72 73 74 75

# 源码目录说明
	/xxl-job-admin					【调度中心】:负责管理调度信息,按照调度配置发出调度请求;
	/xxl-job-core					公共依赖
	/xxl-job-executor-example	【执行器】:负责接收调度请求并执行任务逻辑;
	/db		建表脚本
	/doc	用户手册
X
init  
xueli.xue 已提交
76
	
X
xueli.xue 已提交
77
# Tips
X
xueli.xue 已提交
78
	更多接入公司,欢迎在https://github.com/xuxueli/xxl-job/issues/1 登记。
X
xueli.xue 已提交
79
	我司大众点评已接入XXL-JOB,内部别名《Ferrari》(于V1.1.x版本,XXL-JOB正式应用于我司,内部定制别名为 “Ferrari”,新接入应用推荐使用最新版本V1.3.x)。自2016-01-21接入至2016-05-20未知,内部XXL-JOB系统已调度40000余次,表现优异。新接入应用推荐使用最新版本V1.3,因为经过两个大版本的更新,系统的任务模型、UI交互模型以及底层调度通讯模型都有了较大的提升,核心功能更加稳定高效。
X
xueli.xue 已提交
80 81 82
	
	
![image](http://images2015.cnblogs.com/blog/554415/201605/554415-20160513183306234-1939652116.png)
X
xueli.xue 已提交
83

X
xueli.xue 已提交
84
技术的发展离不开你的支持,请作者喝杯咖啡吧!