xxl-job与springboot的整合详细步骤(亲测)

一、背景

1.因为公司的需求,我们需要使用xxl-job和springboot的整合,在这里我只是简单的测试一下,把代码分离出去,完成他们的整合测试。

二、环境

1.可以参考我上篇博客进行配置:https://blog.csdn.net/chenmingxu438521/article/details/89222539,里面挺详细的。

三、部署调度中心项目

1.打包调度中心的项目,如下图:

xxl-job与springboot的整合详细步骤(亲测)_第1张图片

2.把打包好的项目通过cmd命令行进行启动:java -jar xxx.jar的方式进行启动。

xxl-job与springboot的整合详细步骤(亲测)_第2张图片

3.启动成功之后通过浏览器进行访问:

xxl-job与springboot的整合详细步骤(亲测)_第3张图片

这样就可以通过打包的方式把调度中心的项目打成jar包的形式模拟tomcat启动,可以通过项目去连接配置中心的项目。

四、调度中心的代码项目开发

1.创建项目

xxl-job与springboot的整合详细步骤(亲测)_第4张图片

2.一路默认,最终的项目结构如下(最终的项目结构就是如下面的项目结构):

xxl-job与springboot的整合详细步骤(亲测)_第5张图片

五、调度中心代码详细讲解

1.application.properties

# web port
server.port=8081
# log config
logging.config=classpath:logback.xml
### xxl-job admin address list, such as "http://address" or "http://address01,http://address02"
xxl.job.admin.addresses=http://127.0.0.1:8080/xxl-job-admin
### xxl-job executor address
xxl.job.executor.appname=xxl-job-executor-sample
xxl.job.executor.ip=
xxl.job.executor.port=9999
### xxl-job, access token
xxl.job.accessToken=
### xxl-job log path
xxl.job.executor.logpath=/data/applogs/xxl-job/jobhandler
### xxl-job log retention days
xxl.job.executor.logretentiondays=-1

2.config目录下的XxlJobConfig.java

@Configuration
@ComponentScan(basePackages = "com.ysfj.springbootxxljob.jobhandler")
public class XxlJobConfig {
    private Logger logger = LoggerFactory.getLogger(XxlJobConfig.class);

    @Value("${xxl.job.admin.addresses}")
    private String adminAddresses;

    @Value("${xxl.job.executor.appname}")
    private String appName;

    @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 XxlJobSpringExecutor xxlJobExecutor() {
        logger.info(">>>>>>>>>>> xxl-job config init.");
        XxlJobSpringExecutor xxlJobSpringExecutor = new XxlJobSpringExecutor();
        xxlJobSpringExecutor.setAdminAddresses(adminAddresses);
        xxlJobSpringExecutor.setAppName(appName);
        xxlJobSpringExecutor.setIp(ip);
        xxlJobSpringExecutor.setPort(port);
        xxlJobSpringExecutor.setAccessToken(accessToken);
        xxlJobSpringExecutor.setLogPath(logPath);
        xxlJobSpringExecutor.setLogRetentionDays(logRetentionDays);

        return xxlJobSpringExecutor;
    }

}

3.DemoJobHandler.java具体要测试执行的代码。

@JobHandler(value="demoJobHandler")
@Component
public class DemoJobHandler extends IJobHandler {

	@Override
	public ReturnT 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.logback.xml




    logback
    

    
        
            %d{HH:mm:ss.SSS} %contextName [%thread] %-5level %logger{36} - %msg%n
        
    

    
        ${log.path}
        
            ${log.path}.%d{yyyy-MM-dd}.zip
        
        
            %date %level [%thread] %logger{36} [%file : %line] %msg%n
            
        
    

    
        
        
    

六、测试

1.启动调度中心代码

xxl-job与springboot的整合详细步骤(亲测)_第6张图片

项目全都启动完成了。

七、测试结果

1.新建任务(每分钟执行一次目标代码Cron),jobHandler就是.DemoJobHandler.java具体要测试执行的代码中的value的值。

xxl-job与springboot的整合详细步骤(亲测)_第7张图片

2.项目新建之后的页面

xxl-job与springboot的整合详细步骤(亲测)_第8张图片

3.结果显示

八、结束

上面就是我在原来的基础上修改了一下代码,整合了一下springboot.

Always keep the faith!!!

 

你可能感兴趣的:(springboot)