源碼在碼雲上(git@gitee.com:lynch168/spring-boot.git)java
一、下載xxl-job源碼mysql
xxl-job源碼地址:https://github.com/xuxueli/xxl-jobgit
解壓導入到Eclipse,以下圖所示:
github
二、修改pom.xml文件
2.一、修改/xxl-job-2.0.2/pom.xmlspring
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-source-plugin</artifactId>
<version>${maven-source-plugin.version}</version>
<configuration>
<source>1.8</source>
<target>1.8</target>
</configuration>
<executions>
<execution>
<phase>package</phase>
<goals>
<goal>jar-no-fork</goal>
</goals>
</execution>
</executions>
</plugin>
2.二、修改/xxl-job-admin/pom.xmlsql
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<version>${spring-boot.version}</version>
<configuration>
<source>1.8</source>
<target>1.8</target>
</configuration>
<executions>
<execution>
<goals>
<goal>repackage</goal>
</goals>
</execution>
</executions>
</plugin>
注意:若是jdk爲7此步驟忽略;源碼默認用jdk7編譯,這裏改爲jdk8。數據庫
三、MySQL數據庫
新建數據庫及相關表結構:
執行xxl-job/doc/db/tables_xxl_job.sql數據庫腳本;apache
修改配置
修改/xxl-job-admin/src/main/resources/xxl-job-admin.properties腳本中關於數據庫的配置:瀏覽器
修改/xxl-job-admin/src/main/resources/xxl-job-admin.properties腳本中關於數據庫的配置: xxl.job.db.driverClass=com.mysql.jdbc.Driver xxl.job.db.url=jdbc:mysql://localhost:3306/xxl-job?useUnicode=true&characterEncoding=UTF-8
xxl.job.db.user=root xxl.job.db.password=
四、運行xxl-job-admin服務
4.一、打成war包而後放到tomcat容器中執行;
mvn clean package -Utomcat
4.二、如果調試,則能夠直接在IDEA/Eclipse中配置一下tomcat,而後直接運行
啓動完成後在瀏覽器輸入:http://localhost:8080/xxl-job-admin/
默認帳戶:admin/123456
可在/xxl-job-admin/src/main/resources/xxl-job-admin.properties腳本中進行修改配置;
五、任務調度測試
選用/xxl-job/xxl-job-executor-samples/xxl-job-executor-sample-springbootdemo做爲客戶端測試demo;
5.一、新建JobHandler任務
package com.xxl.job.executor.service.jobhandler; import java.time.LocalDateTime; import java.time.format.DateTimeFormatter; import org.springframework.stereotype.Component; import com.xxl.job.core.biz.model.ReturnT; import com.xxl.job.core.handler.IJobHandler; import com.xxl.job.core.handler.annotation.JobHandler; /** * 任務Handler示例(Bean模式) * <p> * 開發步驟: * 一、繼承"IJobHandler":「com.xxl.job.core.handler.IJobHandler」; * 二、註冊到Spring容器:添加「@Component」註解,被Spring容器掃描爲Bean實例; * 三、註冊到執行器工廠:添加「@JobHandler(value="自定義jobhandler名稱")」註解,註解value值對應的是調度中心新建任務的JobHandler屬性的值。 * 四、執行日誌:須要經過 "XxlJobLogger.log" 打印執行日誌; */ @JobHandler(value = "helloJobHandler") @Component public class HelloJobHandler extends IJobHandler { @Override public ReturnT<String> execute(String param) { String now = LocalDateTime.now().format(DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss")); System.out.println(now + "XXL-JOB, Hello World."); return SUCCESS; } }
5.二、配置
配置腳本/xxl-job/xxl-job-executor-samples/xxl-job-executor-sample-springboot/src/main/resources/application.properties
xxl.job.admin.addresses=http://127.0.0.1:8080/xxl-job-admin
5.三、構建打包
$ cd /xxl-job/xxl-job-executor-samples/xxl-job-executor-sample-springboot/
$ mvn clean package -U
$ cd target
5.四、啓動多個客戶端服務
java -jar xxl-job-executor-sample-springboot-2.0.2.jar --server.port=8901 --xxl.job.executor.port=8801
java -jar xxl-job-executor-sample-springboot-2.0.2.jar --server.port=8902 --xxl.job.executor.port=8802
或者經過IDE啓動XxlJobExecutorApplication入口類
自此要確保xxl-job-admin、xxl-job-executor-sample-springboot成功運行。
六、後臺管理頁面配置任務
6.一、執行器
執行器管理 -> 新建執行器
新建執行器的參數,跟/xxl-job-executor-sample-springboot/src/main/resources/application.properties文件一致,以下:
### xxl-job executor address xxl.job.executor.appname=xxl-job-executor-sample xxl.job.executor.ip= xxl.job.executor.port=9999
6.二、任務
任務管理 -> 新建任務
運行模式:@JobHandler(value = "helloJobHandler")中配置的value
點擊"啓動"按鈕,執行任務,此時在控制檯會看到以下打印信息:
2019-04-28 17:02:10XXL-JOB, Hello World. 2019-04-28 17:02:15XXL-JOB, Hello World. 2019-04-28 17:02:20XXL-JOB, Hello World. 2019-04-28 17:02:25XXL-JOB, Hello World. 2019-04-28 17:02:30XXL-JOB, Hello World. 2019-04-28 17:02:35XXL-JOB, Hello World. 2019-04-28 17:02:40XXL-JOB, Hello World. 2019-04-28 17:02:45XXL-JOB, Hello World.
七、查看調度日誌