添加 solon 的集成适配

pull/25/head
noear 4 years ago
parent ca2ab5cfe0
commit 525cf9239a

@ -0,0 +1,57 @@
package com.xxl.job.core.executor.impl;
import org.noear.solon.annotation.Bean;
import org.noear.solon.annotation.Configuration;
import org.noear.solon.annotation.Inject;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
/**
* @author noear 2021/5/22 created
*/
@Configuration
public class XxlJobSolonAutoConfig {
private static final Logger logger = LoggerFactory.getLogger(XxlJobSolonAutoConfig.class);
@Inject("${xxl.job.admin.addresses}")
private String adminAddresses;
@Inject("${xxl.job.accessToken}")
private String accessToken;
@Inject("${xxl.job.executor.appname}")
private String appname;
@Inject("${xxl.job.executor.address}")
private String address;
@Inject("${xxl.job.executor.ip}")
private String ip;
@Inject("${xxl.job.executor.port}")
private int port;
@Inject("${xxl.job.executor.logpath}")
private String logPath;
@Inject("${xxl.job.executor.logretentiondays}")
private int logRetentionDays;
@Bean
public XxlJobSolonExecutor xxlJobExecutor() {
logger.info(">>>>>>>>>>> xxl-job config init.");
XxlJobSolonExecutor executor = new XxlJobSolonExecutor();
executor.setAdminAddresses(adminAddresses);
executor.setAppname(appname);
executor.setAddress(address);
executor.setIp(ip);
executor.setPort(port);
executor.setAccessToken(accessToken);
executor.setLogPath(logPath);
executor.setLogRetentionDays(logRetentionDays);
return executor;
}
}

@ -2,41 +2,24 @@ package com.xxl.job.core.executor.impl;
import com.xxl.job.core.executor.XxlJobExecutor;
import com.xxl.job.core.glue.GlueFactory;
import com.xxl.job.core.handler.annotation.XxlJob;
import com.xxl.job.core.handler.impl.MethodJobHandler;
import org.noear.solon.SolonApp;
import org.noear.solon.core.Aop;
import org.noear.solon.core.BeanExtractor;
import org.noear.solon.core.BeanWrap;
import org.noear.solon.core.Plugin;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import java.lang.reflect.Method;
/**
* xxl-job executor (for solon)
*
* @author noear 2021/5/22 created
*/
public class XxlJobSolonExecutor extends XxlJobExecutor implements Plugin, BeanExtractor<XxlJob> {
public class XxlJobSolonExecutor extends XxlJobExecutor {
private static final Logger logger = LoggerFactory.getLogger(XxlJobSolonExecutor.class);
@Override
public void start(SolonApp app) {
// init JobHandler Repository (for method)
Aop.context().beanExtractorAdd(XxlJob.class, this);
public void start() throws Exception {
// refresh GlueFactory
GlueFactory.refreshInstance(2);
// super start
try {
super.start();
} catch (Exception e) {
throw new RuntimeException(e);
}
super.start();
}
// destroy
@ -44,44 +27,4 @@ public class XxlJobSolonExecutor extends XxlJobExecutor implements Plugin, BeanE
public void destroy() {
super.destroy();
}
@Override
public void doExtract(BeanWrap wrap, Method method, XxlJob anno) {
String name = anno.value();
if (name.trim().length() == 0) {
throw new RuntimeException("xxl-job method-jobhandler name invalid, for[" + wrap.clz() + "#" + method.getName() + "] .");
}
if (loadJobHandler(name) != null) {
throw new RuntimeException("xxl-job jobhandler[" + name + "] naming conflicts.");
}
method.setAccessible(true);
// init and destory
Method initMethod = null;
Method destroyMethod = null;
if (anno.init().trim().length() > 0) {
try {
initMethod = wrap.clz().getDeclaredMethod(anno.init());
initMethod.setAccessible(true);
} catch (NoSuchMethodException e) {
throw new RuntimeException("xxl-job method-jobhandler initMethod invalid, for[" + wrap.clz() + "#" + method.getName() + "] .");
}
}
if (anno.destroy().trim().length() > 0) {
try {
destroyMethod = wrap.clz().getDeclaredMethod(anno.destroy());
destroyMethod.setAccessible(true);
} catch (NoSuchMethodException e) {
throw new RuntimeException("xxl-job method-jobhandler destroyMethod invalid, for[" + wrap.clz() + "#" + method.getName() + "] .");
}
}
// registry jobhandler
registJobHandler(name, new MethodJobHandler(wrap.raw(), method, initMethod, destroyMethod));
}
}

@ -0,0 +1,72 @@
package com.xxl.job.core.executor.impl;
import com.xxl.job.core.executor.XxlJobExecutor;
import com.xxl.job.core.handler.annotation.XxlJob;
import com.xxl.job.core.handler.impl.MethodJobHandler;
import org.noear.solon.SolonApp;
import org.noear.solon.core.Aop;
import org.noear.solon.core.BeanExtractor;
import org.noear.solon.core.BeanWrap;
import org.noear.solon.core.Plugin;
import java.lang.reflect.Method;
/**
* @author noear 2021/5/22 created
*/
public class XxlJobSolonPlugin implements Plugin, BeanExtractor<XxlJob> {
@Override
public void start(SolonApp app) {
Aop.context().beanExtractorAdd(XxlJob.class, this);
Aop.context().beanMake(XxlJobSolonAutoConfig.class);
XxlJobSolonExecutor executor = Aop.get(XxlJobSolonExecutor.class);
Aop.beanOnloaded(() -> {
try {
executor.start();
} catch (Exception e) {
throw new RuntimeException(e);
}
});
}
@Override
public void doExtract(BeanWrap wrap, Method method, XxlJob anno) {
String name = anno.value();
if (name.trim().length() == 0) {
throw new RuntimeException("xxl-job method-jobhandler name invalid, for[" + wrap.clz() + "#" + method.getName() + "] .");
}
if (XxlJobExecutor.loadJobHandler(name) != null) {
throw new RuntimeException("xxl-job jobhandler[" + name + "] naming conflicts.");
}
method.setAccessible(true);
// init and destory
Method initMethod = null;
Method destroyMethod = null;
if (anno.init().trim().length() > 0) {
try {
initMethod = wrap.clz().getDeclaredMethod(anno.init());
initMethod.setAccessible(true);
} catch (NoSuchMethodException e) {
throw new RuntimeException("xxl-job method-jobhandler initMethod invalid, for[" + wrap.clz() + "#" + method.getName() + "] .");
}
}
if (anno.destroy().trim().length() > 0) {
try {
destroyMethod = wrap.clz().getDeclaredMethod(anno.destroy());
destroyMethod.setAccessible(true);
} catch (NoSuchMethodException e) {
throw new RuntimeException("xxl-job method-jobhandler destroyMethod invalid, for[" + wrap.clz() + "#" + method.getName() + "] .");
}
}
// registry jobhandler
XxlJobExecutor.registJobHandler(name, new MethodJobHandler(wrap.raw(), method, initMethod, destroyMethod));
}
}

@ -1,20 +1,15 @@
package com.xxl.job.core.glue.impl;
import com.xxl.job.core.glue.GlueFactory;
import org.noear.solon.Solon;
import org.noear.solon.core.Aop;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
/**
* @author noear 2021/5/22 created
*/
public class SolonGlueFactory extends GlueFactory {
private static Logger logger = LoggerFactory.getLogger(SolonGlueFactory.class);
/**
* inject action of solon
*
* @param instance
*/
@Override
@ -23,10 +18,6 @@ public class SolonGlueFactory extends GlueFactory {
return;
}
if (Solon.global() == null) {
return;
}
Aop.inject(instance);
}
}

@ -0,0 +1 @@
solon.plugin=com.xxl.job.core.executor.impl.XxlJobSolonPlugin
Loading…
Cancel
Save