百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

详解:基于Quartz的调度系统 - Marble

ccwgpt 2024-09-18 12:26 40 浏览 0 评论

更多深度文章,请关注云计算频道:https://yq.aliyun.com/cloud

摘要: 实际项目中需要用到JOB的场景非常多,通常需要JOB的业务都需要如下基本功能:

1)集群环境单实例调度;

2)JOB可视化启停;

3)JOB频率可视化配置;

单应用使用JOB开发适配的需求的调度功能过滤繁琐,开销太大,考虑提供统一的调度系统对外提供JOB的调度服务。

Marble简介

Marble是一款基于Quartz的计划任务调度系统,提供基本的任务定时调度功能。Marble包含两部分:

  • 1)Marble OFFLINE: 一套可视化的JOB配置系统。包含JOB的启停、频率配置、调度日志查看等功能;

  • 2)Marble AGENT:以Jar包形式整合进接入Marble的第三方应用,透明化Job的调度过程;详情见<< Marble使用>>章节

OFFLINE>>

为了可视化管理JOB,提供一个前端基于Bootstrap, 后端采用SpringMVC + MyBatis + MySql结构的控制台。提供基本的JOB的增删改查,启动/暂停等操作。

Marble部署图如下:

目前版本Marble提供的功能如下:

  • 基本JOB管理(增删改查、暂停/启动);

  • JOB执行参数传递的支持;

  • 同步JOB和异步JOB支持;

  • CRON表达式生成控件;

  • 多种Misfire策略配置;

  • 集群环境部署(不重复执行);

  • 集群的软负载均衡;

  • Spring整合;

Marble使用

接入Marble步骤

服务端=>

1. 引入相关Jar包(Netty等)

1. 定义Job的具体实现类(Spring中的Bean)

1. Spring中配置Job的实现类

OFFLINE端=>

1. 配置对应应用和Job信息(配合权限管理)

接入Marble - 服务端

  1. 引入相关Jar包(以Maven为例)

    注:依赖marble-agent包(自己通过源代码的marble-server模块生成)和Thrift包

<!-- Marble相关 --> <dependency> <groupId>com.github.jxdong</groupId> <artifactId>marble-agent</artifactId> <version>1.0.1</version></dependency><!-- Netty相关 --><dependency> <groupId>io.netty</groupId> <artifactId>netty-all</artifactId> <version>4.0.4.Final</version></dependency>

2.定义Job具体实现类

定义java类继承父类MarbleJob,覆盖方法execute (当Job被调用时会执行execute下的内容)。

//异步JOB@Componentpublic class TestMarbleJob1 extends MarbleJob { private Logger logger = LoggerFactory.getLogger(TestMarbleJob1.class); @Override public void execute(String param) { logger.info(" 异步 JOB1 执行正常: {}", param); }}//同步JOB@Componentpublic class TestSyncMarbleJob1 extends MarbleJob { private Logger logger = LoggerFactory.getLogger(TestSyncMarbleJob1.class); @Override public Result executeSync(String param) { logger.info(" 同步 JOB1(3S) 执行正常: {}", param); try { Thread.sleep(3000); } catch (InterruptedException e) { e.printStackTrace(); } return Result.SUCCESS(); }}
  1. Spring中添加Job配置

marble框架中已经自定义了Spring标签方便直接配置。

示例配置如下:

<marble:scheduler id="Scheduler001" port="9091" appCode="8890"> <marble:job name="Job1" description="jobDescription1" ref="testMarbleJob1"/> <marble:job name="Job2" description="jobDescription2" ref="testSyncMarbleJob1"/></marble:scheduler>

配置解释:

配置了一个名称为Scheduler001的计划任务(job组),在9091端口上暴露服务。

Scheduler001下包含了两个Job:job1和job2.

Job1的实现类是 Spring bean - testMarbleJob1

Job2的实现类是Spring Bean – testSyncMarbleJob1

Marble标签详解:

<marble:scheduler/>: 计划任务配置。一个应用可以配置多个计划任务,每个计划任务暴露在一个IP的端口下,一个计划任务中可以包含多个Job。

属性是否必填描述
id必填ID属性,英文+数字的组合来定义该计划任务的唯一标识。
host非必填所在服务器的IP地址。指定后Marble会尝试将服务暴露在该IP下。不是必填项。由于集群,建议该字段不填,Marble默认会自动获取;
port必填计划任务暴露的端口号。指明该计划任务暴露在机器的哪个端口下,Marble随Spring启动后会尝试打开本机的该端口并暴露服务。
appCode(必填)所在应用的APPID。为了在同一台机器上区别不同的应用,以免调用时混淆。

<marble:job/>: 计划任务下的job的配置。指明具体任务的别名以及实现类。

属性是否必填描述
name必填给当前Job起的别名,在所属的scheduler下必须唯一。
description非必填ob的描述信息,仅用来便于开发者自己识别,非必填。
ref必填Job的具体实现类,必须指向存在的一个Spring Bean。值为bean的name。且该bean必须继承自MarbleJob并覆盖execute方法。Job被调用时会执行execute方法,因此执行逻辑要写在execute中。

接入Marble - OFFLINE端

1、添加相关应用

  • 应用Code:唯一的APPID

  • 应用name:应用name必须与server端中marble:scheduler/标签的appCode属性值一致

  • 应用描述

  • 应用拥有者:输入员工号

  • Marble版本号:2.0.0开始支持Netty

2、应用下添加运行的服务器(可添加多台)

  • 服务器组:默认DEFAULT

  • 服务器name:组内唯一

  • 服务器描述

3、应用下添加Scheduler

  • Scheduler名称:唯一Scheduler

  • Scheduler 描述

  • 服务器相关信息(点击选中输入打开的端口号)

4、Scheduler下添加多个Job

  • Job名称:唯一job

  • job 描述

  • Cron表达式: 通过控件选择(具体含义,请 自行百度Cron表达式)

  • Misfire策略选择(目前提供三种方式)

  • Job执行参数:String类型

Marble原理介绍

Marble的核心其实有两个部分:

  • 1)Job的调度;

  • 2)与服务端的通讯;

Marble的job调度使用了Quartz – 一款流行的开源作业调度框架。

与Job服务端的通讯使用了Apache Thrift / Netty(2.0.0开始) - 一款开源的高效RPC框架。

Marble在两个开源框架基础上做了必要的封装和针对公司使用的定制化修改。

Marble实现原理 - 一次JOB调度过程

调度服务与job服务交互:

1. 服务端(Job执行服务器)随spring启动打开Socket端口;

2. OFFLINE配置执行频率后,到达job执行时间,通过SOCKET与job服务器建立连接;

3. 调用job服务器的execute方法(不等待返回),关闭本次socket连接;

Marble实现原理 - 集群支持

TODO

Marble实现原理 - Misfire策略

存在的问题 + 后续计划

  • 由于集群依赖于DB,如果大量JOB管理会造成DB的资源竞争加剧,从而引发JOB的misfire;

  • 更多功能等待添加,比如:监控,报警,分析等;

  • JOB的执行是单机不能发挥集群的优势;

  • 准备接入zookeeper,摒弃手动配置服务器,采用自发现,自维护;

  • ...

TODO

github第一版代码: https://github.com/jeff-dong/marble

关于作者

Java菜鸟。联系方式djx_19881022@163.com or dongjianxing@aliyun.com

相关推荐

公司组织架构及部门职责#管理制度 #薪酬绩效 #组织架构

...

终于把“公司组织架构与管理部岗位配置”整理好了,拿来即用!

...

老板看完这份“公司组织架构详解”就解放了!

...

丨公司丨公司大架构整理汇总

注:本文转自团队成员原创作品,特此鸣谢(公号:法海图鉴)今日话题公司大架构整理背景介绍经过前几期话题对各种企业类型的介绍,想必大家已经有了初步认识。之后我将带着大家开启对公司的深入了解。本期...

图解物理--八年级物理下册最全知识框架导图

第七章力1力2弹力3重力第八章运动和力1牛顿第一定律2二力平衡3摩擦力第九章压强1压强2液体压强3大气压强4流体压强与流速的关系第十章浮力1浮力2阿基米德原理3物体的浮沉条件及应用第十一章功...

八年级上册生物,思维导图,期末高分必备资料,家长收藏

这是八年级上册生物的思维导图,孩子在背诵知识点的时候,可以看一下知识点在导图中的位置,形成对知识点整体的把握,有助于学生拿高分,特别是图片中带红色星星的部分,更是要注意背诵,是重点内容。家长可以把图片...

2019政府工作报告精华,这张思维导图里全都有

每经记者:李可愚每经编辑:陈星每日经济新闻

图解薪酬体系结构设计

...

司考复习独家总结!一张图总结行政法知识结构体系

作为三大实体法之一,行政法的分值在60分左右,行政法在司法考试中一直比较平稳常规,没有偏题怪题,还是比较容易得分的。小编要提醒大家,在3月之前要把三大实体法学习一遍。下图是厚大在线360导学师小周总结...

一图读懂香港国安新架构:各职位人选公布 有官员曾强硬喊话乱港分子

实用干货!高中物理框架图,让零碎知识“串联”起来

高中物理学习一定要抓好逻辑结构大框架!了解整个知识框架体系后,更易抓住骨干知识,干掉重难知识点~今天给大家分享高中物理的框架图同学们赶紧收藏起来吧!力学知识结构图光学知识结构图热学、原子物理知识结构图...

254m超高层办公楼型钢砼框架-核心筒结构图

高度类别:超高层建筑钢筋混凝土结构:框架,框架核心筒钢结构:钢框架建筑功能:办公包含:办公楼57层(-3层)254.150m钻孔灌注桩桩+筏板型钢混凝土框架-钢筋混凝土核心筒西裙房2层(-...

砖混结构与框架结构,究竟有何区别?千万别被坑!

现在买房装修的人最怕啥?不是价格高,而是房子不安全!两种主流建筑结构,砖混靠墙,框架靠柱子,选错了隔墙都可能要命。简单说,砖混便宜但别碰高层,框架贵点但能保命。砖混那些承重墙根本不能拆,想砸墙改个开放...

大师一百——高中化学必考:《元素周期律》考点框架图

今天大师给大家带来的是高中化学的《元素周期律》考点框架图,高中的同学必须牢记于心,这种重要的考点,考试是一定会考的!化学大师...

需求分析框架图

需求分析框架图

取消回复欢迎 发表评论: