nacos 源碼解析系列(五)

TaskManager 任務(wù)管理的使用

nacos 中很多地方使用了TaskManager 睛驳,所以我們得先了解下這個(gè)類是干啥的,方便后面閱讀不吃力膜廊。

先說(shuō)結(jié)論乏沸,TaskManager 可以看作是一個(gè)待執(zhí)行任務(wù)的集合,用于處理一定要執(zhí)行成功的任務(wù)單線程的處理任務(wù)爪瓜,保證任務(wù)一定被執(zhí)行成功蹬跃;如果執(zhí)行失敗了,任務(wù)會(huì)被重新放入集合中等待下一次的消費(fèi)铆铆。

AbstractTask

AbstractTask 是個(gè)抽象類蝶缀,所有需要被執(zhí)行的任務(wù)都會(huì)繼承這個(gè)類,這個(gè)類主要提供執(zhí)行任務(wù)所需要的數(shù)據(jù)和方法薄货;例如:

   /**
     * Task time interval between twice processing, unit is millisecond.
     */
    private long taskInterval;
    
    /**
     * The time which was processed at last time, unit is millisecond.
     */
    private long lastProcessTime;

  public boolean shouldProcess() {
        return (System.currentTimeMillis() - this.lastProcessTime >= this.taskInterval);
    }

TaskProcessor任務(wù)處理器

TaskProcessor 是任務(wù)處理器接口,它有個(gè)方法

  boolean process(String taskType, AbstractTask task);

用于執(zhí)行對(duì)應(yīng)的AbstractTask任務(wù)類; 不同的任務(wù)類型,可以實(shí)現(xiàn)自己的執(zhí)行任務(wù)邏輯;

TaskManager任務(wù)管理類

TaskManager 是個(gè)任務(wù)管理類;

它里面有兩個(gè)屬性保存了待消費(fèi)的任務(wù)AbstractTask,和任務(wù)執(zhí)行需要的TaskProcessor;

如果taskProcessors中沒(méi)有找到對(duì)應(yīng)的任務(wù)執(zhí)行器,那么它里面有一個(gè)默認(rèn)執(zhí)行器會(huì)執(zhí)行

 private TaskProcessor defaultTaskProcessor;

使用用例

nacos 配置中心模塊很重要的一個(gè)功能就是翁都,在初始化的時(shí)候以及每隔一段時(shí)間就回去數(shù)據(jù)庫(kù)中把所有數(shù)據(jù)Dump到磁盤中;Dump就是一個(gè)任務(wù)類 AbstractTask;我們上面說(shuō)過(guò)谅猾,AbstractTask 就是一個(gè)信息承載對(duì)象柄慰,主要給TaskProcessor 提供所需要的數(shù)據(jù),我們看看DumpTask :

DumpTask

 public DumpTask(String groupKey, long lastModified, String handleIp) {
        this.groupKey = groupKey;
        this.lastModified = lastModified;
        this.handleIp = handleIp;
        this.isBeta = false;
        this.tag = null;
        // retry interval: 1s
        setTaskInterval(1000L);
    }

既然有DumpTask任務(wù)類,那肯定就有對(duì)應(yīng)的任務(wù)處理器類DumpProcessor;

DumpProcessor

DumpProcessor 是DumpTask任務(wù)的執(zhí)行器;執(zhí)行器中的方法

  public boolean process(String taskType, AbstractTask task) {}

代碼太長(zhǎng)就不在這里分析了,它里面主要做的操作就是 保存配置文件到本地磁盤中税娜,并緩存md5詳細(xì)可以參考后面文章DumpService如何將配置文件全部Dump到磁盤中

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末坐搔,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子敬矩,更是在濱河造成了極大的恐慌概行,老刑警劉巖,帶你破解...
    沈念sama閱讀 219,270評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件谤绳,死亡現(xiàn)場(chǎng)離奇詭異占锯,居然都是意外死亡袒哥,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,489評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門消略,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)堡称,“玉大人,你說(shuō)我怎么就攤上這事艺演∪唇簦” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 165,630評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵胎撤,是天一觀的道長(zhǎng)晓殊。 經(jīng)常有香客問(wèn)我,道長(zhǎng)伤提,這世上最難降的妖魔是什么巫俺? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,906評(píng)論 1 295
  • 正文 為了忘掉前任,我火速辦了婚禮肿男,結(jié)果婚禮上介汹,老公的妹妹穿的比我還像新娘。我一直安慰自己舶沛,他們只是感情好嘹承,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,928評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著如庭,像睡著了一般叹卷。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上坪它,一...
    開(kāi)封第一講書(shū)人閱讀 51,718評(píng)論 1 305
  • 那天骤竹,我揣著相機(jī)與錄音,去河邊找鬼哟楷。 笑死瘤载,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的卖擅。 我是一名探鬼主播鸣奔,決...
    沈念sama閱讀 40,442評(píng)論 3 420
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼惩阶!你這毒婦竟也來(lái)了挎狸?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 39,345評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤断楷,失蹤者是張志新(化名)和其女友劉穎锨匆,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,802評(píng)論 1 317
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡恐锣,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,984評(píng)論 3 337
  • 正文 我和宋清朗相戀三年茅主,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片土榴。...
    茶點(diǎn)故事閱讀 40,117評(píng)論 1 351
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡诀姚,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出玷禽,到底是詐尸還是另有隱情赫段,我是刑警寧澤,帶...
    沈念sama閱讀 35,810評(píng)論 5 346
  • 正文 年R本政府宣布矢赁,位于F島的核電站糯笙,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏撩银。R本人自食惡果不足惜给涕,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,462評(píng)論 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望额获。 院中可真熱鬧稠炬,春花似錦、人聲如沸咪啡。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 32,011評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)撤摸。三九已至,卻和暖如春褒纲,著一層夾襖步出監(jiān)牢的瞬間准夷,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,139評(píng)論 1 272
  • 我被黑心中介騙來(lái)泰國(guó)打工莺掠, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留衫嵌,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,377評(píng)論 3 373
  • 正文 我出身青樓彻秆,卻偏偏與公主長(zhǎng)得像楔绞,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子唇兑,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,060評(píng)論 2 355