Elastic-job 介紹與使用

目標

把定時任務通過集群的方式進行管理調度泥畅,并采用分布式部署丁鹉,保證系統(tǒng)的高可用瓜贾,提高了容錯胆敞。那么如何保證定時任務只在集群的某一個節(jié)點上執(zhí)行着帽,或者一個任務如何拆分為多個獨立的任務項,由分布式的機器去分別執(zhí)行移层, 眾多的定時任務如何統(tǒng)一管理仍翰,現(xiàn)在有很多成熟的分布式定時任務框架,都能很好的實現(xiàn)上述的功能观话。

基本概念

elastic-job 是由當當網(wǎng)基于quartz 二次開發(fā)之后的分布式調度解決方案 予借, 由兩個相對獨立的子項目Elastic-Job-Lite和Elastic-Job-Cloud組成 。
elastic-job主要的設計理念是無中心化的分布式定時調度框架,思路來源于Quartz的基于數(shù)據(jù)庫的高可用方案蕾羊。但數(shù)據(jù)庫沒有分布式協(xié)調功能喧笔,所以在高可用方案的基礎上增加了彈性擴容和數(shù)據(jù)分片的思路帽驯,以便于更大限度的利用分布式服務器的資源龟再。

1. 分片

任務的分布式執(zhí)行,需要將一個任務拆分為多個獨立的任務項尼变,然后由分布式的服務器分別執(zhí)行某一個或幾個分片項利凑。

例如:有一個遍歷數(shù)據(jù)庫某張表的作業(yè),現(xiàn)有2臺服務器嫌术。
為了快速的執(zhí)行作業(yè)哀澈,那么每臺服務器應執(zhí)行作業(yè)的50%。 為滿足此需求度气,可將作業(yè)分成2片割按,每臺服務器執(zhí)行1片。
作業(yè)遍歷數(shù)據(jù)的邏輯可以為:服務器A遍歷ID以奇數(shù)結尾的數(shù)據(jù)磷籍;服務器B遍歷ID以偶數(shù)結尾的數(shù)據(jù)适荣。
如果分成10片,則服務器A被分配到分片項0,1,2,3,4院领;服務器B被分配到分片項5,6,7,8,9弛矛。
作業(yè)遍歷數(shù)據(jù)的邏輯可以為:服務器A遍歷ID以0-4結尾的數(shù)據(jù);服務器B遍歷ID以5-9結尾的數(shù)據(jù)

2. 分片項與業(yè)務處理解耦

Elastic-Job并不直接提供數(shù)據(jù)處理的功能比然,框架只會將分片項分配至各個運行中的作業(yè)服務器丈氓,開發(fā)者需要自行處理分片項與真實數(shù)據(jù)的對應關系。以上面例子分成10片為例强法,框架只負責決定服務器分配到哪些分片項万俗,由作業(yè)分配策略決定,但是每個分片處理哪一部分數(shù)據(jù)饮怯,比如第一個分片處理id以0-4結尾的數(shù)據(jù)闰歪,是由開發(fā)者去決定和處理的。

3. 中心化

xxl-job是中心化設計硕淑,在xxl-job中课竣,所有定時任務的執(zhí)行是在調度中心判斷作業(yè)到了執(zhí)行的時間,然后通知業(yè)務系統(tǒng)去執(zhí)行置媳,即是作業(yè)節(jié)點并不知道自己應該什么時候執(zhí)行定時任務于樟,只能通過調度中心去決定作業(yè)的執(zhí)行。缺點是部署麻煩拇囊。

4. 去中心化

elastic-job是去中心化設計迂曲,作業(yè)調度中心節(jié)點,各個作業(yè)節(jié)點是自治的寥袭,作業(yè)框架的程序在到達相應時間點時各自觸發(fā)調度路捧,缺點是可能會存在各個作業(yè)服務器的時間不一致的問題关霸。

使用

1. 引入maven依賴

        <dependency>
            <groupId>com.dangdang</groupId>
            <artifactId>elastic-job-lite-spring</artifactId>
            <version>2.1.5</version>
        </dependency>

        <dependency>
            <artifactId>elastic-job-lite-core</artifactId>
            <groupId>com.dangdang</groupId>
            <version>2.1.5</version>
        </dependency>

2. 配置注冊中心

    <reg:zookeeper id="regCenter" server-lists="192.168.3.191:2181" namespace="elastic-job-zookeeper" base-sleep-time-milliseconds="${baseSleepTimeMilliseconds}" max-sleep-time-milliseconds="${maxSleepTimeMilliseconds}" max-retries="${maxRetries}" />

image.png

3. 事件追蹤(可選)

    <bean id="elasticJobLog" class="com.alibaba.druid.pool.DruidDataSource" init-method="init"  destroy-method="close">
        <!--<property name="driverClassName" value="${event.rdb.driver}"/>-->
        <property name="url" value="${event.rdb.url}"/>
        <property name="username" value="${event.rdb.username}"/>
        <property name="password" value="${event.rdb.password}"/>
    </bean>

4.作業(yè)開發(fā)

package com.isuwang.soa.crm.dbc.action.shareCrm

import java.util.{Date, Optional}
...

@Transactional(value = "crm", rollbackFor = Array(classOf[Exception]))
class FxxkUpdateRecordAction() extends Action[Unit] with SimpleJob{

  override def preCheck: Unit = {}

  override def action: Unit = {
    val beginTime = System.currentTimeMillis()
    rangeConditions.append(rangeCondition)
    searchQuery.rangeConditions(rangeConditions)

    getDatas(fXRecords)

    // 同步
    fXRecords.foreach(x => {
      val tripList = getTableColumnValue(x)
      tripList.foreach(trip => {
        try {
          executeUpdate(trip._4, trip, x)
        } catch {
          case e: Throwable => {
            logger.error(e.getMessage, e)
            logger.info("=====>紛享更新回訪記錄失敗內容id:{}", x._id)
          }
        }
      })
    })
    logger.info(s"====>${getClass.getName}耗時:{}秒", (System.currentTimeMillis() - beginTime) / 1000)
  }
...
  override def execute(shardingContext: ShardingContext): Unit = action
}
    <job:simple id="FxxkUpdateRecordAction" class="com.isuwang.soa.crm.dbc.action.shareCrm.FxxkUpdateRecordAction" registry-center-ref="regCenter" sharding-total-count="1" cron="0 40 * * * ? "  failover="true" description="每晚定時統(tǒng)計獲取紛享CRM當日更新的回訪記錄" overwrite="true"  event-trace-rdb-data-source="elasticJobLog" />

failover:是否開啟任務執(zhí)行失效轉移,開啟表示如果作業(yè)在一次任務執(zhí)行中途宕機杰扫,允許將該次未完成的任務在另一作業(yè)節(jié)點上補償執(zhí)行
description:作業(yè)描述
overwrite:本地配置是否可覆蓋注冊中心配置队寇,如果可覆蓋,每次啟動作業(yè)都以本地配置為準
event-trace-rdb-data-source:作業(yè)事件追蹤的數(shù)據(jù)源Bean引用

實現(xiàn)原理

1. 作業(yè)啟動

image.png

2. 作業(yè)執(zhí)行

image.png
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末章姓,一起剝皮案震驚了整個濱河市佳遣,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌凡伊,老刑警劉巖零渐,帶你破解...
    沈念sama閱讀 207,113評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異系忙,居然都是意外死亡诵盼,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,644評論 2 381
  • 文/潘曉璐 我一進店門银还,熙熙樓的掌柜王于貴愁眉苦臉地迎上來风宁,“玉大人,你說我怎么就攤上這事见剩∩迸矗” “怎么了?”我有些...
    開封第一講書人閱讀 153,340評論 0 344
  • 文/不壞的土叔 我叫張陵苍苞,是天一觀的道長固翰。 經(jīng)常有香客問我,道長羹呵,這世上最難降的妖魔是什么骂际? 我笑而不...
    開封第一講書人閱讀 55,449評論 1 279
  • 正文 為了忘掉前任,我火速辦了婚禮冈欢,結果婚禮上歉铝,老公的妹妹穿的比我還像新娘。我一直安慰自己凑耻,他們只是感情好太示,可當我...
    茶點故事閱讀 64,445評論 5 374
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著香浩,像睡著了一般类缤。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上邻吭,一...
    開封第一講書人閱讀 49,166評論 1 284
  • 那天餐弱,我揣著相機與錄音,去河邊找鬼。 笑死膏蚓,一個胖子當著我的面吹牛瓢谢,可吹牛的內容都是我干的。 我是一名探鬼主播驮瞧,決...
    沈念sama閱讀 38,442評論 3 401
  • 文/蒼蘭香墨 我猛地睜開眼氓扛,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了剧董?” 一聲冷哼從身側響起幢尚,我...
    開封第一講書人閱讀 37,105評論 0 261
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎翅楼,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體真慢,經(jīng)...
    沈念sama閱讀 43,601評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡毅臊,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 36,066評論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了黑界。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片管嬉。...
    茶點故事閱讀 38,161評論 1 334
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖朗鸠,靈堂內的尸體忽然破棺而出蚯撩,到底是詐尸還是另有隱情,我是刑警寧澤烛占,帶...
    沈念sama閱讀 33,792評論 4 323
  • 正文 年R本政府宣布胎挎,位于F島的核電站,受9級特大地震影響忆家,放射性物質發(fā)生泄漏犹菇。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 39,351評論 3 307
  • 文/蒙蒙 一芽卿、第九天 我趴在偏房一處隱蔽的房頂上張望揭芍。 院中可真熱鬧,春花似錦卸例、人聲如沸称杨。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,352評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽姑原。三九已至,卻和暖如春旦装,著一層夾襖步出監(jiān)牢的瞬間页衙,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,584評論 1 261
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留店乐,地道東北人艰躺。 一個月前我還...
    沈念sama閱讀 45,618評論 2 355
  • 正文 我出身青樓,卻偏偏與公主長得像眨八,于是被迫代替她去往敵國和親腺兴。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 42,916評論 2 344

推薦閱讀更多精彩內容