【項目描述】
前段時間專門獨立了一個spring boot服務,用於做和第三方erp系統的對接工作。此服務的第一個需求工作就是可以通過不同的規則,設置不同的定時任務,從而獲取erp系統的商品數據。所以,系統架構采用了xxl-job實現分布式定時任務。
【學習背景】
此項目不是我負責的,在上個月同事讓我幫忙處理一個問題,便帶給了我學習的機會,這個框架已經在線上環境使用,但框架也不是我參與搭建的,所以還是找到官方文檔和項目實例,積累下技術與項目經驗。本篇博客是一個簡單的demo實例,主要總結下如何將此框架與我們的項目結合。
【實例搭建】
初始化“調度數據庫”
下載項目源碼,獲取“調度數據庫初始化SQL腳本”,正常情況下生成16張表。
sql腳本位置: /xxl-job/doc/db/tables_xxl_job.sql
項目源碼地址:https://github.com/xuxueli/xxl-job
在IDEA中,我們可以直接選擇通過github地址新建項目:
配置部署“調度中心"
調度中心配置文件地址:
/xxl-job/xxl-job-admin/src/main/resources/xxl-job-admin.properties
我們只需要將數據庫連接配置修改成自己的環境:
部署項目
正確進行上述配置后,我們可將項目編譯打war包部署到tomcat中。調度中心訪問地址:http://localhost:8080/xxl-job-admin (默認8080端口,該地址執行器將會使用到,作為回調地址)
我使用的是IDEA中Smart Tomcat部署的項目:
部署成功的話,你可以看到如下界面:
使用管理系統,在“任務管理"中,新建一個定時任務,填寫好相關的配置信息
使用管理系統,在“執行器管理”中配置一個執行器,也就是我們的項目中需要用到的
至此,調度中心的部署和配置工作結束了。下面是將此配置與我們的項目結合。只是一個demo實例,我就新建了一個spring boot框架項目,加入xxl-job框架搭建步驟如下:
1.項目加入maven依賴
<!-- http://repo1.maven.org/maven2/com/xuxueli/xxl-job-core/ --> <dependency> <groupId>com.xuxueli</groupId> <artifactId>xxl-job-core</artifactId> <version>1.9.1</version> </dependency>
2.xxlJobConfig配置類
@Slf4j @Configuration //掃描定時任務設置包路徑 @ComponentScan(basePackages = "com.uqiauto.springbootxxljob.job") public class XxlJobConfig { @Value("${xxl.job.admin.address}") private String adminAddresses; @Value("${xxl.job.executor.appname}") private String appName; @Value("${xxl.job.alarmEmail}") private String alarmEmail; @Value("${xxl.job.executor.ip}") private String ip; @Value("${xxl.job.executor.port}") private int port; @Value("${xxl.job.accessToken}") private String accessToken; @Value("${xxl.job.executor.logpath}") private String logPath; @Value("${xxl.job.executor.logretentiondays}") private int logRetentionDays; @Bean(initMethod = "start", destroyMethod = "destroy") public XxlJobExecutor xxlJobExecutor() { log.info(">>>>>>>>>>> xxl-job config init."); XxlJobExecutor xxlJobExecutor = new XxlJobExecutor(); xxlJobExecutor.setAdminAddresses(adminAddresses); xxlJobExecutor.setAppName(appName); xxlJobExecutor.setIp(ip); xxlJobExecutor.setPort(port); xxlJobExecutor.setAccessToken(accessToken); xxlJobExecutor.setLogPath(logPath); xxlJobExecutor.setLogRetentionDays(logRetentionDays); return xxlJobExecutor; } public String getAdminAddresses() { return adminAddresses; } public String getAppName() { return appName; } public String getIp() { return ip; } public int getPort() { return port; } public String getAccessToken() { return accessToken; } public String getLogPath() { return logPath; } public int getLogRetentionDays() { return logRetentionDays; } public String getAlarmEmail() { return alarmEmail; } }
3.定時任務設置demo job
/** * 任務Handler示例(Bean模式) * * 開發步驟: * 1、繼承"IJobHandler":“com.xxl.job.core.handler.IJobHandler”; * 2、注冊到Spring容器:添加“@Component”注解,被Spring容器掃描為Bean實例; * 3、注冊到執行器工廠:添加“@JobHandler(value="自定義jobhandler名稱")”注解,注解value值對應的是調度中心新建任務的JobHandler屬性的值。 * 4、執行日志:需要通過 "XxlJobLogger.log" 打印執行日志; * * @author xuxueli 2015-12-19 19:43:36 */ @JobHandler(value="demoJobHandler") @Component public class DemoJobHandler extends IJobHandler { @Override public ReturnT<String> execute(String param) throws Exception { XxlJobLogger.log("XXL-JOB, Hello World."); for (int i = 0; i < 5; i++) { XxlJobLogger.log("beat at:" + i); TimeUnit.SECONDS.sleep(2); } return SUCCESS; } }
4.項目中配置xxl-job框架需要用到的信息
xxl.job: admin.address: http://localhost:8088/xxl-job-admin/ accessToken: alarmEmail: 18333617859@163.com executor: appname: xxl-job-executor-sample ip: port: 9999 logpath: /data/applogs/xxl-job/jobhandler #執行器Log文件定期清理功能,指定日志保存天數,日志文件過期自動刪除。限制至少保持3天,否則功能不生效; logretentiondays: -1
至此,整個搭建步驟就完成了。我設置的定時任務是每小時執行一次,同時也支持我們在管理系統頁面去手動執行,最終我們可以通過管理系統去查看到定時任務執行的相關日志信息:
每條日志的詳細信息:
【學習總結】
本篇博客只是一個簡單的教程,將xxl-job分布式定時任務框架結合到一個spring boot 項目中,后面還會深入學習此分布式定時任務框架的其他知識,將此分布式定時任務框架與其他框架進行對比學習。