mirror of
https://github.com/PowerJob/PowerJob.git
synced 2025-07-17 00:00:04 +08:00
feat: CSInitializerFactory support graalvm #868
This commit is contained in:
parent
dd3a17275f
commit
b822a685f4
@ -4,9 +4,11 @@ import lombok.extern.slf4j.Slf4j;
|
|||||||
import org.apache.commons.lang3.exception.ExceptionUtils;
|
import org.apache.commons.lang3.exception.ExceptionUtils;
|
||||||
import org.reflections.Reflections;
|
import org.reflections.Reflections;
|
||||||
import tech.powerjob.common.OmsConstant;
|
import tech.powerjob.common.OmsConstant;
|
||||||
|
import tech.powerjob.common.enums.Protocol;
|
||||||
import tech.powerjob.common.exception.PowerJobException;
|
import tech.powerjob.common.exception.PowerJobException;
|
||||||
import tech.powerjob.remote.framework.cs.CSInitializer;
|
import tech.powerjob.remote.framework.cs.CSInitializer;
|
||||||
|
|
||||||
|
import java.util.Optional;
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -18,8 +20,25 @@ import java.util.Set;
|
|||||||
@Slf4j
|
@Slf4j
|
||||||
class CSInitializerFactory {
|
class CSInitializerFactory {
|
||||||
|
|
||||||
|
private static final String OFFICIAL_HTTP_CS_INITIALIZER = "tech.powerjob.remote.http.HttpVertxCSInitializer";
|
||||||
|
/**
|
||||||
|
* 未来底层框架摆脱 vertx 时可能会用这个 classname,or 开发者自己实现的 http 协议也可以用这个 classname,总之预留战未来
|
||||||
|
*/
|
||||||
|
private static final String OFFICIAL_HTTP_CS_INITIALIZER2 = "tech.powerjob.remote.http.HttpCSInitializer";
|
||||||
|
private static final String OFFICIAL_AKKA_CS_INITIALIZER = "tech.powerjob.remote.akka.AkkaCSInitializer";
|
||||||
|
|
||||||
|
private static final String EXTEND_CS_INITIALIZER_PATTERN = "tech.powerjob.remote.%s.CSInitializer";
|
||||||
|
|
||||||
static CSInitializer build(String targetType) {
|
static CSInitializer build(String targetType) {
|
||||||
|
|
||||||
|
CSInitializer officialCSInitializer = tryLoadCSInitializerByClassName(targetType);
|
||||||
|
if (officialCSInitializer != null) {
|
||||||
|
return officialCSInitializer;
|
||||||
|
}
|
||||||
|
|
||||||
|
log.info("[CSInitializerFactory] try load CSInitializerFactory by name failed, start to use Reflections!");
|
||||||
|
|
||||||
|
// JAVA SPI 机制太笨了,短期内继续保留 Reflections 官网下高版本兼容性
|
||||||
Reflections reflections = new Reflections(OmsConstant.PACKAGE);
|
Reflections reflections = new Reflections(OmsConstant.PACKAGE);
|
||||||
Set<Class<? extends CSInitializer>> cSInitializerClzSet = reflections.getSubTypesOf(CSInitializer.class);
|
Set<Class<? extends CSInitializer>> cSInitializerClzSet = reflections.getSubTypesOf(CSInitializer.class);
|
||||||
|
|
||||||
@ -41,4 +60,52 @@ class CSInitializerFactory {
|
|||||||
|
|
||||||
throw new PowerJobException(String.format("can't load CSInitializer[%s], ensure your package name start with 'tech.powerjob' and import the dependencies!", targetType));
|
throw new PowerJobException(String.format("can't load CSInitializer[%s], ensure your package name start with 'tech.powerjob' and import the dependencies!", targetType));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 官方组件直接使用固定类名尝试加载,确保 reflections 不兼容情况下,至少能使用官方通讯协议
|
||||||
|
* @param targetType 协议类型
|
||||||
|
* @return CSInitializer
|
||||||
|
*/
|
||||||
|
private static CSInitializer tryLoadCSInitializerByClassName(String targetType) {
|
||||||
|
|
||||||
|
if (Protocol.HTTP.name().equalsIgnoreCase(targetType)) {
|
||||||
|
Optional<CSInitializer> httpCsIOpt = tryLoadCSInitializerByClzName(OFFICIAL_HTTP_CS_INITIALIZER);
|
||||||
|
if (httpCsIOpt.isPresent()) {
|
||||||
|
return httpCsIOpt.get();
|
||||||
|
}
|
||||||
|
Optional<CSInitializer> httpCsIOpt2 = tryLoadCSInitializerByClzName(OFFICIAL_HTTP_CS_INITIALIZER2);
|
||||||
|
if (httpCsIOpt2.isPresent()) {
|
||||||
|
return httpCsIOpt2.get();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (Protocol.AKKA.name().equalsIgnoreCase(targetType)) {
|
||||||
|
Optional<CSInitializer> akkaCSIOpt = tryLoadCSInitializerByClzName(OFFICIAL_AKKA_CS_INITIALIZER);
|
||||||
|
if (akkaCSIOpt.isPresent()) {
|
||||||
|
return akkaCSIOpt.get();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// 尝试加载按规范命名的处理器,比如使用方自定义了 http2 协议,将其类名定为 tech.powerjob.remote.http2.CSInitializer 依然可确保在 Reflections 不可用的情况下完成加载
|
||||||
|
String clz = String.format(EXTEND_CS_INITIALIZER_PATTERN, targetType);
|
||||||
|
Optional<CSInitializer> extOpt = tryLoadCSInitializerByClzName(clz);
|
||||||
|
return extOpt.orElse(null);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
private static Optional<CSInitializer> tryLoadCSInitializerByClzName(String clzName) {
|
||||||
|
try {
|
||||||
|
log.info("[CSInitializerFactory] try to load CSInitializer by classname: {}", clzName);
|
||||||
|
Class<?> clz = Class.forName(clzName);
|
||||||
|
CSInitializer o = (CSInitializer) clz.getDeclaredConstructor().newInstance();
|
||||||
|
log.info("[CSInitializerFactory] load CSInitializer[{}] successfully, obj: {}", clzName, o);
|
||||||
|
return Optional.of(o);
|
||||||
|
} catch (ClassNotFoundException ce) {
|
||||||
|
log.warn("[CSInitializerFactory] load CSInitializer by classname[{}] failed due to ClassNotFound: {}", clzName, ExceptionUtils.getMessage(ce));
|
||||||
|
} catch (Exception e) {
|
||||||
|
log.warn("[CSInitializerFactory] load CSInitializer by classname[{}] failed.", clzName, e);
|
||||||
|
}
|
||||||
|
return Optional.empty();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -41,6 +41,8 @@ import java.util.concurrent.TimeUnit;
|
|||||||
* - vertx 唯一的缺点是其作为相对上层的框架,可能存在较为严重的包冲突问题,尤其是对于那些本身跑在 vertx-framework 上的用户
|
* - vertx 唯一的缺点是其作为相对上层的框架,可能存在较为严重的包冲突问题,尤其是对于那些本身跑在 vertx-framework 上的用户
|
||||||
* - 不过该问题可以通过更换协议解决,预计后续提供一个基于 netty 和自定义协议的实现
|
* - 不过该问题可以通过更换协议解决,预计后续提供一个基于 netty 和自定义协议的实现
|
||||||
*
|
*
|
||||||
|
* 20240316 note:注意类名被强依赖,后续若有改动需要同步更改
|
||||||
|
*
|
||||||
* @author tjq
|
* @author tjq
|
||||||
* @since 2022/12/31
|
* @since 2022/12/31
|
||||||
*/
|
*/
|
||||||
|
Loading…
x
Reference in New Issue
Block a user