diff --git a/pom.xml b/pom.xml index 9ff7185d..97c73c75 100644 --- a/pom.xml +++ b/pom.xml @@ -31,6 +31,7 @@ 4.0.51 4.5.4 + 1.3 4.1 3.7 diff --git a/xxl-job-executor-samples/pom.xml b/xxl-job-executor-samples/pom.xml index bcbd0f13..34479551 100644 --- a/xxl-job-executor-samples/pom.xml +++ b/xxl-job-executor-samples/pom.xml @@ -14,6 +14,7 @@ xxl-job-executor-sample-spring xxl-job-executor-sample-springboot xxl-job-executor-sample-jfinal + xxl-job-executor-sample-nutz \ No newline at end of file diff --git a/xxl-job-executor-samples/xxl-job-executor-sample-nutz/pom.xml b/xxl-job-executor-samples/xxl-job-executor-sample-nutz/pom.xml new file mode 100644 index 00000000..7ccd6ba8 --- /dev/null +++ b/xxl-job-executor-samples/xxl-job-executor-sample-nutz/pom.xml @@ -0,0 +1,35 @@ + + + + xxl-job-executor-samples + com.xuxueli + 1.8.2-SNAPSHOT + + 4.0.0 + xxl-job-executor-sample-nutz + war + + + + org.nutz + nutz + 1.r.62 + + + + + com.xuxueli + xxl-job-core + ${project.parent.version} + + + + org.slf4j + slf4j-log4j12 + ${slf4j-api.version} + + + + \ No newline at end of file diff --git a/xxl-job-executor-samples/xxl-job-executor-sample-nutz/src/main/java/com/xuxueli/executor/sample/nutz/MainModule.java b/xxl-job-executor-samples/xxl-job-executor-sample-nutz/src/main/java/com/xuxueli/executor/sample/nutz/MainModule.java new file mode 100644 index 00000000..01e1b34f --- /dev/null +++ b/xxl-job-executor-samples/xxl-job-executor-sample-nutz/src/main/java/com/xuxueli/executor/sample/nutz/MainModule.java @@ -0,0 +1,26 @@ +package com.xuxueli.executor.sample.nutz; + +import org.nutz.mvc.annotation.Encoding; +import org.nutz.mvc.annotation.Fail; +import org.nutz.mvc.annotation.IocBy; +import org.nutz.mvc.annotation.Localization; +import org.nutz.mvc.annotation.Modules; +import org.nutz.mvc.annotation.Ok; +import org.nutz.mvc.annotation.SetupBy; +import org.nutz.mvc.ioc.provider.ComboIocProvider; +/** + * + * @author 邓华锋 + * + */ +@IocBy(type=ComboIocProvider.class,args={"*org.nutz.ioc.loader.json.JsonLoader","ioc/", + "*org.nutz.ioc.loader.annotation.AnnotationIocLoader","com.xuxueli"}) +@Encoding(input="utf-8",output="utf-8") +@Modules(scanPackage=true) +@Localization("msg") +@Ok("json") +@Fail("json") +@SetupBy(MainSetup.class) +public class MainModule { + +} diff --git a/xxl-job-executor-samples/xxl-job-executor-sample-nutz/src/main/java/com/xuxueli/executor/sample/nutz/MainSetup.java b/xxl-job-executor-samples/xxl-job-executor-sample-nutz/src/main/java/com/xuxueli/executor/sample/nutz/MainSetup.java new file mode 100644 index 00000000..b2192392 --- /dev/null +++ b/xxl-job-executor-samples/xxl-job-executor-sample-nutz/src/main/java/com/xuxueli/executor/sample/nutz/MainSetup.java @@ -0,0 +1,55 @@ +package com.xuxueli.executor.sample.nutz; + +import org.nutz.ioc.IocException; +import org.nutz.ioc.impl.PropertiesProxy; +import org.nutz.log.Log; +import org.nutz.log.Logs; +import org.nutz.mvc.NutConfig; +import org.nutz.mvc.Setup; + +import com.xxl.job.core.executor.XxlJobExecutor; +import com.xxl.job.core.handler.IJobHandler; + +/** + * + * @author 邓华锋 + * + */ +public class MainSetup implements Setup { + public static final Log log = Logs.get(); + XxlJobExecutor xxlJobExecutor = null; + + @Override + public void init(NutConfig cfg) { + // 通用注册IJobHandler + String[] names = cfg.getIoc().getNamesByType(IJobHandler.class); + for (String name : names) { + XxlJobExecutor.registJobHandler(name, cfg.getIoc().get(IJobHandler.class, name)); + } + // load executor prop + PropertiesProxy xxlJobProp = cfg.getIoc().get(PropertiesProxy.class, "conf"); + + // init executor + xxlJobExecutor = new XxlJobExecutor(); + xxlJobExecutor.setIp(xxlJobProp.get("xxl.job.executor.ip")); + xxlJobExecutor.setPort(xxlJobProp.getInt("xxl.job.executor.port")); + xxlJobExecutor.setAppName(xxlJobProp.get("xxl.job.executor.appname")); + xxlJobExecutor.setAdminAddresses(xxlJobProp.get("xxl.job.admin.addresses")); + xxlJobExecutor.setLogPath(xxlJobProp.get("xxl.job.executor.logpath")); + xxlJobExecutor.setAccessToken(xxlJobProp.get("xxl.job.accessToken")); + + // start executor + try { + xxlJobExecutor.start(); + } catch (Exception e) { + log.error(e.getMessage(), e); + } + } + + @Override + public void destroy(NutConfig cfg) { + if (xxlJobExecutor != null) { + xxlJobExecutor.destroy(); + } + } +} diff --git a/xxl-job-executor-samples/xxl-job-executor-sample-nutz/src/main/java/com/xuxueli/executor/sample/nutz/jobhandler/DemoJobHandler.java b/xxl-job-executor-samples/xxl-job-executor-sample-nutz/src/main/java/com/xuxueli/executor/sample/nutz/jobhandler/DemoJobHandler.java new file mode 100644 index 00000000..b37eb256 --- /dev/null +++ b/xxl-job-executor-samples/xxl-job-executor-sample-nutz/src/main/java/com/xuxueli/executor/sample/nutz/jobhandler/DemoJobHandler.java @@ -0,0 +1,36 @@ +package com.xuxueli.executor.sample.nutz.jobhandler; + +import java.util.concurrent.TimeUnit; + +import org.nutz.ioc.loader.annotation.IocBean; + +import com.xxl.job.core.biz.model.ReturnT; +import com.xxl.job.core.handler.IJobHandler; +import com.xxl.job.core.log.XxlJobLogger; + + +/** + * 任务Handler的一个Demo(Bean模式) + * + * 开发步骤: + * 1、继承 “IJobHandler” ; + * 2、执行日志:需要通过 "XxlJobLogger.log" 打印执行日志; + * 3、在 "JFinalCoreConfig" 中注册,执行Jobhandler名称; + * + * @author xuxueli 2015-12-19 19:43:36 + */ +@IocBean +public class DemoJobHandler extends IJobHandler { + + @Override + public ReturnT execute(String... params) 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 ReturnT.SUCCESS; + } + +} diff --git a/xxl-job-executor-samples/xxl-job-executor-sample-nutz/src/main/java/com/xuxueli/executor/sample/nutz/jobhandler/ShardingJobHandler.java b/xxl-job-executor-samples/xxl-job-executor-sample-nutz/src/main/java/com/xuxueli/executor/sample/nutz/jobhandler/ShardingJobHandler.java new file mode 100644 index 00000000..db31758c --- /dev/null +++ b/xxl-job-executor-samples/xxl-job-executor-sample-nutz/src/main/java/com/xuxueli/executor/sample/nutz/jobhandler/ShardingJobHandler.java @@ -0,0 +1,38 @@ +package com.xuxueli.executor.sample.nutz.jobhandler; + +import org.nutz.ioc.loader.annotation.IocBean; + +import com.xxl.job.core.biz.model.ReturnT; +import com.xxl.job.core.handler.IJobHandler; +import com.xxl.job.core.log.XxlJobLogger; +import com.xxl.job.core.util.ShardingUtil; + + +/** + * 分片广播任务 + * + * @author xuxueli 2017-07-25 20:56:50 + */ +@IocBean +public class ShardingJobHandler extends IJobHandler { + + @Override + public ReturnT execute(String... params) throws Exception { + + // 分片参数 + ShardingUtil.ShardingVO shardingVO = ShardingUtil.getShardingVo(); + XxlJobLogger.log("分片参数:当前分片序号 = {0}, 总分片数 = {1}", shardingVO.getIndex(), shardingVO.getTotal()); + + // 业务逻辑 + for (int i = 0; i < shardingVO.getTotal(); i++) { + if (i == shardingVO.getIndex()) { + XxlJobLogger.log("第 {0} 片, 命中分片开始处理", i); + } else { + XxlJobLogger.log("第 {0} 片, 忽略", i); + } + } + + return ReturnT.SUCCESS; + } + +} diff --git a/xxl-job-executor-samples/xxl-job-executor-sample-nutz/src/main/java/com/xuxueli/executor/sample/nutz/module/IndexModule.java b/xxl-job-executor-samples/xxl-job-executor-sample-nutz/src/main/java/com/xuxueli/executor/sample/nutz/module/IndexModule.java new file mode 100644 index 00000000..0a103e6c --- /dev/null +++ b/xxl-job-executor-samples/xxl-job-executor-sample-nutz/src/main/java/com/xuxueli/executor/sample/nutz/module/IndexModule.java @@ -0,0 +1,18 @@ +package com.xuxueli.executor.sample.nutz.module; + +import org.nutz.ioc.loader.annotation.IocBean; +import org.nutz.mvc.annotation.At; +import org.nutz.mvc.annotation.Ok; +/** + * + * @author 邓华锋 + * + */ +@IocBean +public class IndexModule { + + @At + @Ok("jsp:index") + public void index() { + } +} diff --git a/xxl-job-executor-samples/xxl-job-executor-sample-nutz/src/main/resources/custom/xxl-job-executor.properties b/xxl-job-executor-samples/xxl-job-executor-sample-nutz/src/main/resources/custom/xxl-job-executor.properties new file mode 100644 index 00000000..6617671c --- /dev/null +++ b/xxl-job-executor-samples/xxl-job-executor-sample-nutz/src/main/resources/custom/xxl-job-executor.properties @@ -0,0 +1,13 @@ +### 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=1024 + +### xxl-job log path +xxl.job.executor.logpath=/data/applogs/xxl-job/jobhandler/ + +### xxl-job, access token +xxl.job.accessToken= \ No newline at end of file diff --git a/xxl-job-executor-samples/xxl-job-executor-sample-nutz/src/main/resources/ioc/dao.js b/xxl-job-executor-samples/xxl-job-executor-sample-nutz/src/main/resources/ioc/dao.js new file mode 100644 index 00000000..cc80b0a7 --- /dev/null +++ b/xxl-job-executor-samples/xxl-job-executor-sample-nutz/src/main/resources/ioc/dao.js @@ -0,0 +1,38 @@ +var ioc = { + conf : { + type : "org.nutz.ioc.impl.PropertiesProxy", + fields : { + paths : [ "custom/" ] + } + }, + /** + * 配置单例job执行 + */ + /*xxlJobExecutor : { + type : "com.xxl.job.core.executor.XxlJobExecutor", + events : { + create : "start", + depose : "destroy" + }, + fields : { + ip : { + java : "$conf.get('xxl.job.executor.ip')" + }, + port : { + java : "$conf.get('xxl.job.executor.port')" + }, + appName : { + java : "$conf.get('xxl.job.executor.appname')" + }, + adminAddresses : { + java : "$conf.get('xxl.job.admin.addresses')" + }, + logPath : { + java : "$conf.get('xxl.job.executor.logpath')" + }, + accessToken : { + java : "$conf.get('xxl.job.accessToken')" + } + } + }*/ +}; \ No newline at end of file diff --git a/xxl-job-executor-samples/xxl-job-executor-sample-nutz/src/main/resources/log4j.xml b/xxl-job-executor-samples/xxl-job-executor-sample-nutz/src/main/resources/log4j.xml new file mode 100644 index 00000000..f6196a83 --- /dev/null +++ b/xxl-job-executor-samples/xxl-job-executor-sample-nutz/src/main/resources/log4j.xml @@ -0,0 +1,27 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/xxl-job-executor-samples/xxl-job-executor-sample-nutz/src/main/webapp/WEB-INF/index.jsp b/xxl-job-executor-samples/xxl-job-executor-sample-nutz/src/main/webapp/WEB-INF/index.jsp new file mode 100644 index 00000000..03f281fd --- /dev/null +++ b/xxl-job-executor-samples/xxl-job-executor-sample-nutz/src/main/webapp/WEB-INF/index.jsp @@ -0,0 +1,12 @@ +<%@ page language="java" contentType="text/html; charset=UTF-8" + pageEncoding="UTF-8"%> + + + + +nutz 执行器启动成功 + + +nutz 执行器启动成功! + + \ No newline at end of file diff --git a/xxl-job-executor-samples/xxl-job-executor-sample-nutz/src/main/webapp/WEB-INF/web.xml b/xxl-job-executor-samples/xxl-job-executor-sample-nutz/src/main/webapp/WEB-INF/web.xml new file mode 100644 index 00000000..97bbf405 --- /dev/null +++ b/xxl-job-executor-samples/xxl-job-executor-sample-nutz/src/main/webapp/WEB-INF/web.xml @@ -0,0 +1,22 @@ + + + xxl-job-executor-sample-nutz + + xxl-job-executor-sample-nutz + org.nutz.mvc.NutFilter + + modules + com.xuxueli.executor.sample.nutz.MainModule + + + + xxl-job-executor-sample-nutz + /* + + + index + + diff --git a/xxl-job-executor-samples/xxl-job-executor-sample-nutz/src/main/webapp/index b/xxl-job-executor-samples/xxl-job-executor-sample-nutz/src/main/webapp/index new file mode 100644 index 00000000..e69de29b