|
|
@ -36,10 +36,8 @@ public class EmbedServer {
|
|
|
|
public void start(final String address, final int port, final String appname, final String accessToken) {
|
|
|
|
public void start(final String address, final int port, final String appname, final String accessToken) {
|
|
|
|
executorBiz = new ExecutorBizImpl();
|
|
|
|
executorBiz = new ExecutorBizImpl();
|
|
|
|
thread = new Thread(new Runnable() {
|
|
|
|
thread = new Thread(new Runnable() {
|
|
|
|
|
|
|
|
|
|
|
|
@Override
|
|
|
|
@Override
|
|
|
|
public void run() {
|
|
|
|
public void run() {
|
|
|
|
|
|
|
|
|
|
|
|
// param
|
|
|
|
// param
|
|
|
|
EventLoopGroup bossGroup = new NioEventLoopGroup();
|
|
|
|
EventLoopGroup bossGroup = new NioEventLoopGroup();
|
|
|
|
EventLoopGroup workerGroup = new NioEventLoopGroup();
|
|
|
|
EventLoopGroup workerGroup = new NioEventLoopGroup();
|
|
|
@ -61,8 +59,6 @@ public class EmbedServer {
|
|
|
|
throw new RuntimeException("xxl-job, EmbedServer bizThreadPool is EXHAUSTED!");
|
|
|
|
throw new RuntimeException("xxl-job, EmbedServer bizThreadPool is EXHAUSTED!");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
try {
|
|
|
|
try {
|
|
|
|
// start server
|
|
|
|
// start server
|
|
|
|
ServerBootstrap bootstrap = new ServerBootstrap();
|
|
|
|
ServerBootstrap bootstrap = new ServerBootstrap();
|
|
|
@ -92,11 +88,9 @@ public class EmbedServer {
|
|
|
|
future.channel().closeFuture().sync();
|
|
|
|
future.channel().closeFuture().sync();
|
|
|
|
|
|
|
|
|
|
|
|
} catch (InterruptedException e) {
|
|
|
|
} catch (InterruptedException e) {
|
|
|
|
if (e instanceof InterruptedException) {
|
|
|
|
|
|
|
|
logger.info(">>>>>>>>>>> xxl-job remoting server stop.");
|
|
|
|
logger.info(">>>>>>>>>>> xxl-job remoting server stop.");
|
|
|
|
} else {
|
|
|
|
} catch (Exception e) {
|
|
|
|
logger.error(">>>>>>>>>>> xxl-job remoting server error.", e);
|
|
|
|
logger.error(">>>>>>>>>>> xxl-job remoting server error.", e);
|
|
|
|
}
|
|
|
|
|
|
|
|
} finally {
|
|
|
|
} finally {
|
|
|
|
// stop
|
|
|
|
// stop
|
|
|
|
try {
|
|
|
|
try {
|
|
|
@ -106,9 +100,7 @@ public class EmbedServer {
|
|
|
|
logger.error(e.getMessage(), e);
|
|
|
|
logger.error(e.getMessage(), e);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
});
|
|
|
|
});
|
|
|
|
thread.setDaemon(true); // daemon, service jvm, user thread leave >>> daemon leave >>> jvm leave
|
|
|
|
thread.setDaemon(true); // daemon, service jvm, user thread leave >>> daemon leave >>> jvm leave
|
|
|
|
thread.start();
|
|
|
|
thread.start();
|
|
|
@ -130,7 +122,7 @@ public class EmbedServer {
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
/**
|
|
|
|
* netty_http
|
|
|
|
* netty_http
|
|
|
|
*
|
|
|
|
* <p>
|
|
|
|
* Copy from : https://github.com/xuxueli/xxl-rpc
|
|
|
|
* Copy from : https://github.com/xuxueli/xxl-rpc
|
|
|
|
*
|
|
|
|
*
|
|
|
|
* @author xuxueli 2015-11-24 22:25:15
|
|
|
|
* @author xuxueli 2015-11-24 22:25:15
|
|
|
@ -141,6 +133,7 @@ public class EmbedServer {
|
|
|
|
private ExecutorBiz executorBiz;
|
|
|
|
private ExecutorBiz executorBiz;
|
|
|
|
private String accessToken;
|
|
|
|
private String accessToken;
|
|
|
|
private ThreadPoolExecutor bizThreadPool;
|
|
|
|
private ThreadPoolExecutor bizThreadPool;
|
|
|
|
|
|
|
|
|
|
|
|
public EmbedHttpServerHandler(ExecutorBiz executorBiz, String accessToken, ThreadPoolExecutor bizThreadPool) {
|
|
|
|
public EmbedHttpServerHandler(ExecutorBiz executorBiz, String accessToken, ThreadPoolExecutor bizThreadPool) {
|
|
|
|
this.executorBiz = executorBiz;
|
|
|
|
this.executorBiz = executorBiz;
|
|
|
|
this.accessToken = accessToken;
|
|
|
|
this.accessToken = accessToken;
|
|
|
@ -149,7 +142,6 @@ public class EmbedServer {
|
|
|
|
|
|
|
|
|
|
|
|
@Override
|
|
|
|
@Override
|
|
|
|
protected void channelRead0(final ChannelHandlerContext ctx, FullHttpRequest msg) throws Exception {
|
|
|
|
protected void channelRead0(final ChannelHandlerContext ctx, FullHttpRequest msg) throws Exception {
|
|
|
|
|
|
|
|
|
|
|
|
// request parse
|
|
|
|
// request parse
|
|
|
|
//final byte[] requestBytes = ByteBufUtil.getBytes(msg.content()); // byteBuf.toString(io.netty.util.CharsetUtil.UTF_8);
|
|
|
|
//final byte[] requestBytes = ByteBufUtil.getBytes(msg.content()); // byteBuf.toString(io.netty.util.CharsetUtil.UTF_8);
|
|
|
|
String requestData = msg.content().toString(CharsetUtil.UTF_8);
|
|
|
|
String requestData = msg.content().toString(CharsetUtil.UTF_8);
|
|
|
@ -175,7 +167,6 @@ public class EmbedServer {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
private Object process(HttpMethod httpMethod, String uri, String requestData, String accessTokenReq) {
|
|
|
|
private Object process(HttpMethod httpMethod, String uri, String requestData, String accessTokenReq) {
|
|
|
|
|
|
|
|
|
|
|
|
// valid
|
|
|
|
// valid
|
|
|
|
if (HttpMethod.POST != httpMethod) {
|
|
|
|
if (HttpMethod.POST != httpMethod) {
|
|
|
|
return new ReturnT<String>(ReturnT.FAIL_CODE, "invalid request, HttpMethod not support.");
|
|
|
|
return new ReturnT<String>(ReturnT.FAIL_CODE, "invalid request, HttpMethod not support.");
|
|
|
@ -191,21 +182,22 @@ public class EmbedServer {
|
|
|
|
|
|
|
|
|
|
|
|
// services mapping
|
|
|
|
// services mapping
|
|
|
|
try {
|
|
|
|
try {
|
|
|
|
if ("/beat".equals(uri)) {
|
|
|
|
switch (uri) {
|
|
|
|
|
|
|
|
case "/beat":
|
|
|
|
return executorBiz.beat();
|
|
|
|
return executorBiz.beat();
|
|
|
|
} else if ("/idleBeat".equals(uri)) {
|
|
|
|
case "/idleBeat":
|
|
|
|
IdleBeatParam idleBeatParam = GsonTool.fromJson(requestData, IdleBeatParam.class);
|
|
|
|
IdleBeatParam idleBeatParam = GsonTool.fromJson(requestData, IdleBeatParam.class);
|
|
|
|
return executorBiz.idleBeat(idleBeatParam);
|
|
|
|
return executorBiz.idleBeat(idleBeatParam);
|
|
|
|
} else if ("/run".equals(uri)) {
|
|
|
|
case "/run":
|
|
|
|
TriggerParam triggerParam = GsonTool.fromJson(requestData, TriggerParam.class);
|
|
|
|
TriggerParam triggerParam = GsonTool.fromJson(requestData, TriggerParam.class);
|
|
|
|
return executorBiz.run(triggerParam);
|
|
|
|
return executorBiz.run(triggerParam);
|
|
|
|
} else if ("/kill".equals(uri)) {
|
|
|
|
case "/kill":
|
|
|
|
KillParam killParam = GsonTool.fromJson(requestData, KillParam.class);
|
|
|
|
KillParam killParam = GsonTool.fromJson(requestData, KillParam.class);
|
|
|
|
return executorBiz.kill(killParam);
|
|
|
|
return executorBiz.kill(killParam);
|
|
|
|
} else if ("/log".equals(uri)) {
|
|
|
|
case "/log":
|
|
|
|
LogParam logParam = GsonTool.fromJson(requestData, LogParam.class);
|
|
|
|
LogParam logParam = GsonTool.fromJson(requestData, LogParam.class);
|
|
|
|
return executorBiz.log(logParam);
|
|
|
|
return executorBiz.log(logParam);
|
|
|
|
} else {
|
|
|
|
default:
|
|
|
|
return new ReturnT<String>(ReturnT.FAIL_CODE, "invalid request, uri-mapping(" + uri + ") not found.");
|
|
|
|
return new ReturnT<String>(ReturnT.FAIL_CODE, "invalid request, uri-mapping(" + uri + ") not found.");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
} catch (Exception e) {
|
|
|
|
} catch (Exception e) {
|
|
|
@ -261,6 +253,4 @@ public class EmbedServer {
|
|
|
|
// stop registry
|
|
|
|
// stop registry
|
|
|
|
ExecutorRegistryThread.getInstance().toStop();
|
|
|
|
ExecutorRegistryThread.getInstance().toStop();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|