SpringCloud2.x Task

Task

簡介

為了短期或者一次性執(zhí)行某種任務,比如統(tǒng)計,更新數(shù)據(jù)等所使用的短期框架,也可以與flow data 大數(shù)據(jù)分析進行結(jié)合,但本文章只說明Task單獨使用

搭建

1. 使用spring cloud的框架

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>

    <groupId>com.demo</groupId>
    <artifactId>task</artifactId>
    <version>1.0</version>

    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.0.5.RELEASE</version>
        <relativePath/>
        <!-- lookup parent thirdpart repository -->
    </parent>

   <dependencies>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
        </dependency>

      <!-- 短期任務 -->
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-task</artifactId>
        </dependency>
       <!-- task依賴龄章,不要去除 -->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-actuator</artifactId>
        </dependency>

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter</artifactId>
        </dependency>

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>

        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-config</artifactId>
        </dependency>
        <!-- jpa jar -->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-data-jpa</artifactId>
        </dependency>

        <dependency>
            <groupId>org.apache.commons</groupId>
            <artifactId>commons-pool2</artifactId>
        </dependency>

    </dependencies>

    <dependencyManagement>
        <dependencies>
            <dependency>
                <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-dependencies</artifactId>
                <version>${spring-cloud.version}</version>
                <type>pom</type>
                <scope>import</scope>
            </dependency>
        </dependencies>
    </dependencyManagement>

    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
        </plugins>
    </build>

</project>

添加注解

在Application中添加注解

@EnableDiscoveryClient
@SpringBootApplication
@EnableConfigurationProperties
@EnableTask
public class Application{
   public static void main(String[] args) {
        SpringApplication.run(Application.class,args);
    }
}

添加任務執(zhí)行

使用注解方式,添加任務乞封,任務的執(zhí)行會分為三部分

  • @BeforeTask 任務開始
  • @AfterTask 任務結(jié)束
  • @FailedTask 任務異常做裙,如果發(fā)生會優(yōu)先結(jié)束執(zhí)行
@Component
public class taskRunner{
    @BeforeTask
    public void onTaskStartup(TaskExecution taskExecution) {
        logger.info("任務執(zhí)行 start");
    }
    @AfterTask
    public void onTaskEnd(TaskExecution taskExecution) {
        logger.info("任務執(zhí)行 end");
    }

    @FailedTask
    public void onTaskEndFailed(TaskExecution taskExecution, Throwable throwable) {
        logger.info("任務執(zhí)行 failed"");
    }
}

這樣就可以正常運行一個簡單的Task了。

配置

一肃晚、配置項說明 TaskConfigurer

TaskConfigurer是一個允許用戶自定義Spring Cloud Task組件配置的策略接口锚贱,其默認實現(xiàn)DefaultTaskConfigurer提供了應用的默認邏輯(當應用上下文中沒有DataSource時使用內(nèi)存Map作為任務倉庫存儲。當上下文中有DataSource時关串,使用依賴于 JDBC 的組件實現(xiàn)任務倉庫惋鸥。)。

這里有個疑問:有數(shù)據(jù)庫的情況下悍缠,必須創(chuàng)建和存儲任務數(shù)據(jù)卦绣,沒辦法不保存數(shù)據(jù)。如下場景飞蚓,更新業(yè)務數(shù)據(jù)庫中數(shù)據(jù)滤港,但是不想在數(shù)據(jù)庫中添加任務的相關(guān)結(jié)構(gòu);或者單獨存儲任務的數(shù)據(jù),在一個任務中執(zhí)行了不同的業(yè)務數(shù)據(jù)的操作溅漾;

TaskConfigurer主要包含三種組件山叮,如表1所示:

組件名 描述 默認值(由 TaskConfigurer 提供)
TaskRepository TaskRepository接口的實現(xiàn)類,作為任務倉庫使用 SimpleTaskRepository
TaskExplorer TaskExplorer接口的實現(xiàn)類(任務探測器是只讀訪問任務倉庫的組件) SimpleTaskExplorer
PlatformTransactionManager 對任務倉庫執(zhí)行更新操作時所使用的事務管理器 如果應用上下文中配置有DataSource添履,默認的事務管理器為DataSourceTransactionManager屁倔。如果應用上下文中沒有數(shù)據(jù)源,則默認的事務管理器是ResourcelessTransactionManager暮胧。

表1 TaskConfigurer的三種主要組件
在定制 TaskConfigurer 時推薦直接繼承已有的成熟TaskConfigurer接口锐借,例如繼承 DefaultTaskConfigurer,覆蓋所需要的getter就足夠了往衷。否則的話钞翔,你需要重寫整個 TaskConfigurer 的邏輯。

二席舍、執(zhí)行方式

spring:
  cloud:
    task:
      closecontext-enabled: true # 執(zhí)行完成后布轿,關(guān)閉服務

三、數(shù)據(jù)庫配置

默認情況下来颤,會使用H2 嵌入式內(nèi)存數(shù)據(jù)庫作為數(shù)據(jù)源來啟動發(fā)布task汰扭,如果需要進行存儲任務執(zhí)行的情況,可以對在配置文件中添加相關(guān)的配置福铅,這里我介紹下使用JPA的使用方式:
spring.cloud.task配置開頭东且,例如:spring.cloud.task.tablePrefix

下面對配置項進行說明:

配置項 說明
tablePrefix 數(shù)據(jù)庫表,命名前綴:默認為TASK_
executionid 任務實例ID本讥,存儲到數(shù)據(jù)庫
external-execution-id 外部任務ID
parent-execution-id 父類任務ID,可以在一個任務中調(diào)用另一個任務
single-instance-enabled 啟用單個實例模式
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末鲁冯,一起剝皮案震驚了整個濱河市拷沸,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌薯演,老刑警劉巖撞芍,帶你破解...
    沈念sama閱讀 210,914評論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異跨扮,居然都是意外死亡序无,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 89,935評論 2 383
  • 文/潘曉璐 我一進店門衡创,熙熙樓的掌柜王于貴愁眉苦臉地迎上來帝嗡,“玉大人,你說我怎么就攤上這事璃氢∮寸瑁” “怎么了?”我有些...
    開封第一講書人閱讀 156,531評論 0 345
  • 文/不壞的土叔 我叫張陵一也,是天一觀的道長巢寡。 經(jīng)常有香客問我喉脖,道長,這世上最難降的妖魔是什么抑月? 我笑而不...
    開封第一講書人閱讀 56,309評論 1 282
  • 正文 為了忘掉前任树叽,我火速辦了婚禮,結(jié)果婚禮上谦絮,老公的妹妹穿的比我還像新娘题诵。我一直安慰自己,他們只是感情好挨稿,可當我...
    茶點故事閱讀 65,381評論 5 384
  • 文/花漫 我一把揭開白布仇轻。 她就那樣靜靜地躺著,像睡著了一般奶甘。 火紅的嫁衣襯著肌膚如雪篷店。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,730評論 1 289
  • 那天臭家,我揣著相機與錄音疲陕,去河邊找鬼。 笑死钉赁,一個胖子當著我的面吹牛蹄殃,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播你踩,決...
    沈念sama閱讀 38,882評論 3 404
  • 文/蒼蘭香墨 我猛地睜開眼诅岩,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了带膜?” 一聲冷哼從身側(cè)響起吩谦,我...
    開封第一講書人閱讀 37,643評論 0 266
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎膝藕,沒想到半個月后式廷,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,095評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡芭挽,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,448評論 2 325
  • 正文 我和宋清朗相戀三年滑废,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片袜爪。...
    茶點故事閱讀 38,566評論 1 339
  • 序言:一個原本活蹦亂跳的男人離奇死亡蠕趁,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出辛馆,到底是詐尸還是另有隱情妻导,我是刑警寧澤,帶...
    沈念sama閱讀 34,253評論 4 328
  • 正文 年R本政府宣布,位于F島的核電站倔韭,受9級特大地震影響术浪,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜寿酌,卻給世界環(huán)境...
    茶點故事閱讀 39,829評論 3 312
  • 文/蒙蒙 一胰苏、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧醇疼,春花似錦硕并、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,715評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至乙濒,卻和暖如春陕赃,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背颁股。 一陣腳步聲響...
    開封第一講書人閱讀 31,945評論 1 264
  • 我被黑心中介騙來泰國打工么库, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人甘有。 一個月前我還...
    沈念sama閱讀 46,248評論 2 360
  • 正文 我出身青樓诉儒,卻偏偏與公主長得像,于是被迫代替她去往敵國和親亏掀。 傳聞我的和親對象是個殘疾皇子忱反,可洞房花燭夜當晚...
    茶點故事閱讀 43,440評論 2 348

推薦閱讀更多精彩內(nèi)容