mirror of
https://gitee.com/BDWare/agent-backend
synced 2025-01-25 09:14:11 +00:00
prune network manager
This commit is contained in:
parent
1ade70df35
commit
40816e8a45
@ -31,10 +31,9 @@ import org.bdware.server.action.FileActions;
|
|||||||
import org.bdware.server.doip.ContractRepositoryMain;
|
import org.bdware.server.doip.ContractRepositoryMain;
|
||||||
import org.bdware.server.http.CMHttpHandler;
|
import org.bdware.server.http.CMHttpHandler;
|
||||||
import org.bdware.server.nodecenter.client.NodeCenterClientHandler;
|
import org.bdware.server.nodecenter.client.NodeCenterClientHandler;
|
||||||
import org.bdware.server.tcp.MasterClientFrameHandler;
|
import org.bdware.server.tcp.TCPClientFrameHandler;
|
||||||
import org.bdware.server.ws.ContractManagerFrameHandler;
|
import org.bdware.server.ws.ContractManagerFrameHandler;
|
||||||
import org.bdware.units.NetworkManager;
|
import org.bdware.units.NetworkManager;
|
||||||
import org.bdware.units.tcp.TCPClientFrameHandler;
|
|
||||||
|
|
||||||
import java.io.*;
|
import java.io.*;
|
||||||
import java.lang.reflect.Field;
|
import java.lang.reflect.Field;
|
||||||
@ -132,9 +131,9 @@ public class CMHttpServer {
|
|||||||
|
|
||||||
// plugins
|
// plugins
|
||||||
CMHttpHandler.wsPluginActions = parseStrAsList(cmdConf.wsPluginActions);
|
CMHttpHandler.wsPluginActions = parseStrAsList(cmdConf.wsPluginActions);
|
||||||
MasterClientFrameHandler.clientToAgentPlugins = parseStrAsList(cmdConf.clientToAgentPlugins);
|
TCPClientFrameHandler.clientToAgentPlugins = parseStrAsList(cmdConf.clientToAgentPlugins);
|
||||||
NodeCenterClientHandler.clientToClusterPlugins = parseStrAsList(cmdConf.clientToClusterPlugins);
|
NodeCenterClientHandler.clientToClusterPlugins = parseStrAsList(cmdConf.clientToClusterPlugins);
|
||||||
TCPClientFrameHandler.tcpPlugins = parseStrAsList(cmdConf.tcpPlugins);
|
org.bdware.units.tcp.TCPClientFrameHandler.tcpPlugins = parseStrAsList(cmdConf.tcpPlugins);
|
||||||
|
|
||||||
if (!cmdConf.debug.isEmpty()) {
|
if (!cmdConf.debug.isEmpty()) {
|
||||||
try {
|
try {
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
package org.bdware.server.ws;
|
package org.bdware.server.action;
|
||||||
|
|
||||||
import com.google.gson.JsonObject;
|
import com.google.gson.JsonObject;
|
||||||
import org.bdware.sc.ContractClient;
|
import org.bdware.sc.ContractClient;
|
@ -19,7 +19,7 @@ import org.bdware.server.GlobalConf;
|
|||||||
import org.bdware.server.action.Action;
|
import org.bdware.server.action.Action;
|
||||||
import org.bdware.server.action.CMActions;
|
import org.bdware.server.action.CMActions;
|
||||||
import org.bdware.server.action.RequestToMaster;
|
import org.bdware.server.action.RequestToMaster;
|
||||||
import org.bdware.server.tcp.MasterClientFrameHandler;
|
import org.bdware.server.tcp.TCPClientFrameHandler;
|
||||||
import org.bdware.server.trustedmodel.ContractUnitStatus;
|
import org.bdware.server.trustedmodel.ContractUnitStatus;
|
||||||
import org.bdware.server.trustedmodel.MasterProxy;
|
import org.bdware.server.trustedmodel.MasterProxy;
|
||||||
import org.bdware.units.function.ExecutionManager;
|
import org.bdware.units.function.ExecutionManager;
|
||||||
@ -37,13 +37,13 @@ public class MasterClientRecoverMechAction {
|
|||||||
new ConcurrentSet<>(); // contracts which don't finish recoverRestart
|
new ConcurrentSet<>(); // contracts which don't finish recoverRestart
|
||||||
public static Map<String, Queue<RequestToMaster>>
|
public static Map<String, Queue<RequestToMaster>>
|
||||||
requestsToMaster; // when master is re-electing,client node cache ites received requests
|
requestsToMaster; // when master is re-electing,client node cache ites received requests
|
||||||
private final MasterClientFrameHandler handler;
|
private final TCPClientFrameHandler handler;
|
||||||
private final MasterClientTCPAction clientAction;
|
private final MasterClientTCPAction clientAction;
|
||||||
private final Map<String, OutputStream> stateFileMap = new HashMap<>();
|
private final Map<String, OutputStream> stateFileMap = new HashMap<>();
|
||||||
private final Map<String, OutputStream> transFileMap = new HashMap<>();
|
private final Map<String, OutputStream> transFileMap = new HashMap<>();
|
||||||
|
|
||||||
public MasterClientRecoverMechAction(
|
public MasterClientRecoverMechAction(
|
||||||
MasterClientFrameHandler handler, MasterClientTCPAction action) {
|
TCPClientFrameHandler handler, MasterClientTCPAction action) {
|
||||||
this.handler = handler;
|
this.handler = handler;
|
||||||
clientAction = action;
|
clientAction = action;
|
||||||
}
|
}
|
||||||
@ -58,7 +58,7 @@ public class MasterClientRecoverMechAction {
|
|||||||
+ contractID
|
+ contractID
|
||||||
+ " masterID="
|
+ " masterID="
|
||||||
+ masterID.substring(0, 5));
|
+ masterID.substring(0, 5));
|
||||||
MasterClientFrameHandler master = MasterProxy.getHandler(masterID);
|
TCPClientFrameHandler master = MasterProxy.getHandler(masterID);
|
||||||
|
|
||||||
Map<String, String> ret = new HashMap<String, String>();
|
Map<String, String> ret = new HashMap<String, String>();
|
||||||
ret.put("action", "askForRecover");
|
ret.put("action", "askForRecover");
|
||||||
|
@ -17,7 +17,7 @@ import org.bdware.sc.units.MultiContractMeta;
|
|||||||
import org.bdware.sc.util.JsonUtil;
|
import org.bdware.sc.util.JsonUtil;
|
||||||
import org.bdware.server.GlobalConf;
|
import org.bdware.server.GlobalConf;
|
||||||
import org.bdware.server.action.*;
|
import org.bdware.server.action.*;
|
||||||
import org.bdware.server.tcp.MasterClientFrameHandler;
|
import org.bdware.server.tcp.TCPClientFrameHandler;
|
||||||
import org.bdware.server.trustedmodel.*;
|
import org.bdware.server.trustedmodel.*;
|
||||||
import org.bdware.units.NetworkManager;
|
import org.bdware.units.NetworkManager;
|
||||||
import org.bdware.units.function.ExecutionManager;
|
import org.bdware.units.function.ExecutionManager;
|
||||||
@ -43,15 +43,15 @@ public class MasterClientTCPAction {
|
|||||||
public static Map<String, MasterClientTCPAction> contractID2MasterInfo =
|
public static Map<String, MasterClientTCPAction> contractID2MasterInfo =
|
||||||
new ConcurrentHashMap<>();
|
new ConcurrentHashMap<>();
|
||||||
static Map<String, KillUnitContractInfo> killUnitContractMap = new ConcurrentHashMap<>();
|
static Map<String, KillUnitContractInfo> killUnitContractMap = new ConcurrentHashMap<>();
|
||||||
private final MasterClientFrameHandler handler;
|
private final TCPClientFrameHandler handler;
|
||||||
private final String master;
|
private final String master;
|
||||||
TimerTask sendPingTask;
|
TimerTask sendPingTask;
|
||||||
TimerTask checkAliveTask;
|
TimerTask checkAliveTask;
|
||||||
MasterClientFrameHandler controller;
|
TCPClientFrameHandler controller;
|
||||||
private long lastMasterPongTime = System.currentTimeMillis();
|
private long lastMasterPongTime = System.currentTimeMillis();
|
||||||
private boolean waitForSetNode = false;
|
private boolean waitForSetNode = false;
|
||||||
|
|
||||||
public MasterClientTCPAction(MasterClientFrameHandler handler, String master) {
|
public MasterClientTCPAction(TCPClientFrameHandler handler, String master) {
|
||||||
this.handler = handler;
|
this.handler = handler;
|
||||||
this.master = master;
|
this.master = master;
|
||||||
}
|
}
|
||||||
@ -741,7 +741,7 @@ public class MasterClientTCPAction {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public void init(MasterClientFrameHandler masterClientFrameHandler) {
|
public void init(TCPClientFrameHandler masterClientFrameHandler) {
|
||||||
LOGGER.info("[MasterClientTCPAction] init : ");
|
LOGGER.info("[MasterClientTCPAction] init : ");
|
||||||
controller = masterClientFrameHandler;
|
controller = masterClientFrameHandler;
|
||||||
controller.sendMsg(
|
controller.sendMsg(
|
||||||
|
@ -11,7 +11,7 @@ import org.bdware.sc.util.JsonUtil;
|
|||||||
import org.bdware.server.GlobalConf;
|
import org.bdware.server.GlobalConf;
|
||||||
import org.bdware.server.action.Action;
|
import org.bdware.server.action.Action;
|
||||||
import org.bdware.server.action.CMActions;
|
import org.bdware.server.action.CMActions;
|
||||||
import org.bdware.server.tcp.MasterClientFrameHandler;
|
import org.bdware.server.tcp.TCPClientFrameHandler;
|
||||||
import org.bdware.server.trustedmodel.MasterProxy;
|
import org.bdware.server.trustedmodel.MasterProxy;
|
||||||
|
|
||||||
import java.io.*;
|
import java.io.*;
|
||||||
@ -23,11 +23,11 @@ import java.util.zip.GZIPOutputStream;
|
|||||||
public class MasterClientTransferAction {
|
public class MasterClientTransferAction {
|
||||||
private static final Logger LOGGER = LogManager.getLogger(MasterClientTransferAction.class);
|
private static final Logger LOGGER = LogManager.getLogger(MasterClientTransferAction.class);
|
||||||
private final String master;
|
private final String master;
|
||||||
MasterClientFrameHandler handler;
|
TCPClientFrameHandler handler;
|
||||||
MasterClientTCPAction action;
|
MasterClientTCPAction action;
|
||||||
private final Map<String, String> id2Memory = new HashMap<>();
|
private final Map<String, String> id2Memory = new HashMap<>();
|
||||||
|
|
||||||
public MasterClientTransferAction(MasterClientFrameHandler h, String pubKey, MasterClientTCPAction a) {
|
public MasterClientTransferAction(TCPClientFrameHandler h, String pubKey, MasterClientTCPAction a) {
|
||||||
handler = h;
|
handler = h;
|
||||||
master = pubKey;
|
master = pubKey;
|
||||||
action = a;
|
action = a;
|
||||||
|
@ -32,7 +32,7 @@ import org.bdware.server.action.p2p.MasterClientRecoverMechAction;
|
|||||||
import org.bdware.server.action.p2p.MasterClientTCPAction;
|
import org.bdware.server.action.p2p.MasterClientTCPAction;
|
||||||
import org.bdware.server.action.p2p.MasterServerRecoverMechAction;
|
import org.bdware.server.action.p2p.MasterServerRecoverMechAction;
|
||||||
import org.bdware.server.action.p2p.MasterServerTCPAction;
|
import org.bdware.server.action.p2p.MasterServerTCPAction;
|
||||||
import org.bdware.server.tcp.MasterClientFrameHandler;
|
import org.bdware.server.tcp.TCPClientFrameHandler;
|
||||||
import org.bdware.server.trustedmodel.MasterProxy;
|
import org.bdware.server.trustedmodel.MasterProxy;
|
||||||
import org.bdware.server.ws.DelimiterCodec;
|
import org.bdware.server.ws.DelimiterCodec;
|
||||||
import org.bouncycastle.pqc.math.linearalgebra.ByteUtils;
|
import org.bouncycastle.pqc.math.linearalgebra.ByteUtils;
|
||||||
@ -448,7 +448,7 @@ public class NodeCenterClientController implements NodeCenterConn {
|
|||||||
|
|
||||||
public void queryUnitContractsID2(String contractID, String master) {
|
public void queryUnitContractsID2(String contractID, String master) {
|
||||||
connectToMaster(master, null); // TODO 等待确保连接成功?
|
connectToMaster(master, null); // TODO 等待确保连接成功?
|
||||||
MasterClientFrameHandler clientHandler = MasterProxy.getHandler(master);
|
TCPClientFrameHandler clientHandler = MasterProxy.getHandler(master);
|
||||||
clientHandler.waitForSetNodeID();
|
clientHandler.waitForSetNodeID();
|
||||||
RecoverMechTimeRecorder.connectMasterFinish = System.currentTimeMillis();
|
RecoverMechTimeRecorder.connectMasterFinish = System.currentTimeMillis();
|
||||||
MasterClientRecoverMechAction.askForRecover(contractID, master, nodeID);
|
MasterClientRecoverMechAction.askForRecover(contractID, master, nodeID);
|
||||||
@ -457,6 +457,7 @@ public class NodeCenterClientController implements NodeCenterConn {
|
|||||||
// TODO add syncPing
|
// TODO add syncPing
|
||||||
public void connectToMaster(String master, String contractID) {
|
public void connectToMaster(String master, String contractID) {
|
||||||
LOGGER.info("[CMClientController] connectToMaster master= " + master);
|
LOGGER.info("[CMClientController] connectToMaster master= " + master);
|
||||||
|
|
||||||
// logger.debug("ConnectToMaster:" + master + "\nMasterRoute:" + slaverRouter.get(master));
|
// logger.debug("ConnectToMaster:" + master + "\nMasterRoute:" + slaverRouter.get(master));
|
||||||
Bootstrap b;
|
Bootstrap b;
|
||||||
MasterProxy.MasterConnector connector = null;
|
MasterProxy.MasterConnector connector = null;
|
||||||
@ -468,7 +469,7 @@ public class NodeCenterClientController implements NodeCenterConn {
|
|||||||
}
|
}
|
||||||
if (connector != null) {
|
if (connector != null) {
|
||||||
b = new Bootstrap();
|
b = new Bootstrap();
|
||||||
MasterClientFrameHandler handler = new MasterClientFrameHandler(master);
|
TCPClientFrameHandler handler = new TCPClientFrameHandler(master);
|
||||||
connector.bootstrap = b;
|
connector.bootstrap = b;
|
||||||
connector.handler = handler;
|
connector.handler = handler;
|
||||||
b.option(ChannelOption.CONNECT_TIMEOUT_MILLIS, 5000);
|
b.option(ChannelOption.CONNECT_TIMEOUT_MILLIS, 5000);
|
||||||
|
@ -1,132 +0,0 @@
|
|||||||
/*
|
|
||||||
* Copyright 2014 The Netty Project
|
|
||||||
*
|
|
||||||
* The Netty Project licenses this file to you under the Apache License,
|
|
||||||
* version 2.0 (the "License"); you may not use this file except in compliance
|
|
||||||
* with the License. You may obtain a copy of the License at:
|
|
||||||
*
|
|
||||||
* http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
*
|
|
||||||
* Unless required by applicable law or agreed to in writing, software
|
|
||||||
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
|
||||||
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
|
||||||
* License for the specific language governing permissions and limitations
|
|
||||||
* under the License.
|
|
||||||
*/
|
|
||||||
package org.bdware.server.nodecenter.client;
|
|
||||||
|
|
||||||
import io.netty.bootstrap.Bootstrap;
|
|
||||||
import io.netty.buffer.Unpooled;
|
|
||||||
import io.netty.channel.Channel;
|
|
||||||
import io.netty.channel.ChannelInitializer;
|
|
||||||
import io.netty.channel.ChannelPipeline;
|
|
||||||
import io.netty.channel.EventLoopGroup;
|
|
||||||
import io.netty.channel.nio.NioEventLoopGroup;
|
|
||||||
import io.netty.channel.socket.SocketChannel;
|
|
||||||
import io.netty.channel.socket.nio.NioSocketChannel;
|
|
||||||
import io.netty.handler.codec.http.HttpClientCodec;
|
|
||||||
import io.netty.handler.codec.http.HttpObjectAggregator;
|
|
||||||
import io.netty.handler.codec.http.websocketx.CloseWebSocketFrame;
|
|
||||||
import io.netty.handler.codec.http.websocketx.PingWebSocketFrame;
|
|
||||||
import io.netty.handler.codec.http.websocketx.TextWebSocketFrame;
|
|
||||||
import io.netty.handler.codec.http.websocketx.WebSocketFrame;
|
|
||||||
import io.netty.handler.codec.http.websocketx.extensions.compression.WebSocketClientCompressionHandler;
|
|
||||||
import io.netty.handler.ssl.SslContext;
|
|
||||||
import io.netty.handler.ssl.SslContextBuilder;
|
|
||||||
import io.netty.handler.ssl.util.InsecureTrustManagerFactory;
|
|
||||||
|
|
||||||
import java.io.BufferedReader;
|
|
||||||
import java.io.InputStreamReader;
|
|
||||||
import java.net.URI;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* This is an example of a WebSocket client.
|
|
||||||
* <p>
|
|
||||||
* In order to run this example you need a compatible WebSocket server.
|
|
||||||
* Therefore you can either start the WebSocket server from the examples by
|
|
||||||
* running {@link io.netty.example.http.websocketx.server.WebSocketServer} or
|
|
||||||
* connect to an existing WebSocket server such as
|
|
||||||
* <a href="http://www.websocket.org/echo.html">ws://echo.websocket.org</a>.
|
|
||||||
* <p>
|
|
||||||
* The client will attempt to connect to the URI passed to it as the first
|
|
||||||
* argument. You don't have to specify any arguments if you want to connect to
|
|
||||||
* the example WebSocket server, as this is the default.
|
|
||||||
*/
|
|
||||||
public final class WebSocketClient {
|
|
||||||
|
|
||||||
static final String URL = "ws://39.106.6.6:8080/SCIDE/SCExecutor";
|
|
||||||
|
|
||||||
public static void main(String[] args) throws Exception {
|
|
||||||
URI uri = new URI(URL);
|
|
||||||
String scheme = uri.getScheme() == null ? "ws" : uri.getScheme();
|
|
||||||
final String host = uri.getHost() == null ? "127.0.0.1" : uri.getHost();
|
|
||||||
final int port;
|
|
||||||
if (uri.getPort() == -1) {
|
|
||||||
if ("ws".equalsIgnoreCase(scheme)) {
|
|
||||||
port = 80;
|
|
||||||
} else if ("wss".equalsIgnoreCase(scheme)) {
|
|
||||||
port = 443;
|
|
||||||
} else {
|
|
||||||
port = -1;
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
port = uri.getPort();
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!"ws".equalsIgnoreCase(scheme) && !"wss".equalsIgnoreCase(scheme)) {
|
|
||||||
System.err.println("Only WS(S) is supported.");
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
final boolean ssl = "wss".equalsIgnoreCase(scheme);
|
|
||||||
final SslContext sslCtx;
|
|
||||||
if (ssl) {
|
|
||||||
sslCtx = SslContextBuilder.forClient().trustManager(InsecureTrustManagerFactory.INSTANCE).build();
|
|
||||||
} else {
|
|
||||||
sslCtx = null;
|
|
||||||
}
|
|
||||||
|
|
||||||
EventLoopGroup group = new NioEventLoopGroup();
|
|
||||||
try {
|
|
||||||
// Connect with V13 (RFC 6455 aka HyBi-17). You can change it to V08 or V00.
|
|
||||||
// If you change it to V00, ping is not supported and remember to change
|
|
||||||
// HttpResponseDecoder to WebSocketHttpResponseDecoder in the pipeline.
|
|
||||||
final NodeCenterClientHandler handler = new NodeCenterClientHandler();
|
|
||||||
|
|
||||||
Bootstrap b = new Bootstrap();
|
|
||||||
b.group(group).channel(NioSocketChannel.class).handler(new ChannelInitializer<SocketChannel>() {
|
|
||||||
@Override
|
|
||||||
protected void initChannel(SocketChannel ch) {
|
|
||||||
ChannelPipeline p = ch.pipeline();
|
|
||||||
if (sslCtx != null) {
|
|
||||||
p.addLast(sslCtx.newHandler(ch.alloc(), host, port));
|
|
||||||
}
|
|
||||||
p.addLast(new HttpClientCodec(), new HttpObjectAggregator(8192),
|
|
||||||
WebSocketClientCompressionHandler.INSTANCE, handler);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
Channel ch = b.connect(uri.getHost(), port).sync().channel();
|
|
||||||
|
|
||||||
BufferedReader console = new BufferedReader(new InputStreamReader(System.in));
|
|
||||||
while (true) {
|
|
||||||
String msg = console.readLine();
|
|
||||||
if (msg == null) {
|
|
||||||
break;
|
|
||||||
} else if ("bye".equalsIgnoreCase(msg)) {
|
|
||||||
ch.writeAndFlush(new CloseWebSocketFrame());
|
|
||||||
ch.closeFuture().sync();
|
|
||||||
break;
|
|
||||||
} else if ("ping".equalsIgnoreCase(msg)) {
|
|
||||||
WebSocketFrame frame = new PingWebSocketFrame(Unpooled.wrappedBuffer(new byte[]{8, 1, 8, 1}));
|
|
||||||
ch.writeAndFlush(frame);
|
|
||||||
} else {
|
|
||||||
WebSocketFrame frame = new TextWebSocketFrame(msg);
|
|
||||||
ch.writeAndFlush(frame);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
} finally {
|
|
||||||
group.shutdownGracefully();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -28,8 +28,8 @@ import java.util.concurrent.Executors;
|
|||||||
import static org.bdware.server.CMHttpServer.pluginLoader;
|
import static org.bdware.server.CMHttpServer.pluginLoader;
|
||||||
|
|
||||||
@ChannelHandler.Sharable
|
@ChannelHandler.Sharable
|
||||||
public class MasterClientFrameHandler extends SimpleChannelInboundHandler<Object> {
|
public class TCPClientFrameHandler extends SimpleChannelInboundHandler<Object> {
|
||||||
private static final Logger LOGGER = LogManager.getLogger(MasterClientFrameHandler.class);
|
private static final Logger LOGGER = LogManager.getLogger(TCPClientFrameHandler.class);
|
||||||
private static final ExecutorService executorService = Executors.newFixedThreadPool(10);
|
private static final ExecutorService executorService = Executors.newFixedThreadPool(10);
|
||||||
public static String[] clientToAgentPlugins;
|
public static String[] clientToAgentPlugins;
|
||||||
public String pubKey;
|
public String pubKey;
|
||||||
@ -42,7 +42,7 @@ public class MasterClientFrameHandler extends SimpleChannelInboundHandler<Object
|
|||||||
private boolean isConnected;
|
private boolean isConnected;
|
||||||
private String master; // master node pubKey
|
private String master; // master node pubKey
|
||||||
|
|
||||||
public MasterClientFrameHandler(String masterPubkey) {
|
public TCPClientFrameHandler(String masterPubkey) {
|
||||||
master = masterPubkey;
|
master = masterPubkey;
|
||||||
actions = new MasterClientTCPAction(this, master);
|
actions = new MasterClientTCPAction(this, master);
|
||||||
recoverActions = new MasterClientRecoverMechAction(this, actions);
|
recoverActions = new MasterClientRecoverMechAction(this, actions);
|
@ -16,7 +16,7 @@ import org.bdware.sc.util.JsonUtil;
|
|||||||
import org.bdware.server.CongestionControl;
|
import org.bdware.server.CongestionControl;
|
||||||
import org.bdware.server.action.CMActions;
|
import org.bdware.server.action.CMActions;
|
||||||
import org.bdware.server.action.p2p.MasterServerTCPAction;
|
import org.bdware.server.action.p2p.MasterServerTCPAction;
|
||||||
import org.bdware.server.tcp.MasterClientFrameHandler;
|
import org.bdware.server.tcp.TCPClientFrameHandler;
|
||||||
|
|
||||||
import java.text.SimpleDateFormat;
|
import java.text.SimpleDateFormat;
|
||||||
import java.util.Date;
|
import java.util.Date;
|
||||||
@ -31,11 +31,7 @@ public class MasterProxy implements MasterStub {
|
|||||||
// nodePubkey,该node作为master的地址
|
// nodePubkey,该node作为master的地址
|
||||||
public static Map<String, String> slaverRouter = new HashMap<>();
|
public static Map<String, String> slaverRouter = new HashMap<>();
|
||||||
|
|
||||||
// static {
|
public static TCPClientFrameHandler getHandler(String masterID) {
|
||||||
// // 和连的所有master心跳
|
|
||||||
// }
|
|
||||||
|
|
||||||
public static MasterClientFrameHandler getHandler(String masterID) {
|
|
||||||
return CONNECTORS.get(masterID).handler;
|
return CONNECTORS.get(masterID).handler;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -189,7 +185,7 @@ public class MasterProxy implements MasterStub {
|
|||||||
|
|
||||||
public static class MasterConnector {
|
public static class MasterConnector {
|
||||||
public Bootstrap bootstrap;
|
public Bootstrap bootstrap;
|
||||||
public MasterClientFrameHandler handler;
|
public TCPClientFrameHandler handler;
|
||||||
}
|
}
|
||||||
|
|
||||||
static class StrCollector extends ResultCallback {
|
static class StrCollector extends ResultCallback {
|
||||||
|
@ -44,9 +44,9 @@ public class NetworkManager {
|
|||||||
public static NetworkManager instance = new NetworkManager();
|
public static NetworkManager instance = new NetworkManager();
|
||||||
private final Map<String, String> peerID2TCPAddress;
|
private final Map<String, String> peerID2TCPAddress;
|
||||||
private final Map<String, TCPClientFrameHandler> tcpClientMap;
|
private final Map<String, TCPClientFrameHandler> tcpClientMap;
|
||||||
private TCPServerFrameHandler tcpHandler;
|
|
||||||
private String tcpNodeCenter;
|
private String tcpNodeCenter;
|
||||||
private String tcpSelf;
|
private String tcpSelf;
|
||||||
|
// connection to node center
|
||||||
private NodeCenterClientHandler nodeCenterClientHandler;
|
private NodeCenterClientHandler nodeCenterClientHandler;
|
||||||
|
|
||||||
public NetworkManager() {
|
public NetworkManager() {
|
||||||
@ -67,16 +67,22 @@ public class NetworkManager {
|
|||||||
return tcpClientMap.containsKey(peer);
|
return tcpClientMap.containsKey(peer);
|
||||||
}
|
}
|
||||||
|
|
||||||
public TCPServerFrameHandler getTCPHandler() {
|
|
||||||
return tcpHandler;
|
|
||||||
}
|
|
||||||
|
|
||||||
private void connectToTCPNodeCenter() {
|
private void connectToTCPNodeCenter() {
|
||||||
final Bootstrap b = new Bootstrap();
|
final Bootstrap b = new Bootstrap();
|
||||||
b.option(ChannelOption.CONNECT_TIMEOUT_MILLIS, 5000);
|
b.option(ChannelOption.CONNECT_TIMEOUT_MILLIS, 5000);
|
||||||
nodeCenterClientHandler = new NodeCenterClientHandler();
|
nodeCenterClientHandler = new NodeCenterClientHandler();
|
||||||
CMActions.manager.nodeCenterConn = nodeCenterClientHandler.controller;
|
CMActions.manager.nodeCenterConn = nodeCenterClientHandler.controller;
|
||||||
setBootstrap(b);
|
EventLoopGroup group = new NioEventLoopGroup();
|
||||||
|
b.group(group);
|
||||||
|
b.channel(NioSocketChannel.class)
|
||||||
|
.handler(
|
||||||
|
new ChannelInitializer<SocketChannel>() {
|
||||||
|
@Override
|
||||||
|
protected void initChannel(SocketChannel ch) {
|
||||||
|
ChannelPipeline p = ch.pipeline();
|
||||||
|
p.addLast(new DelimiterCodec()).addLast(nodeCenterClientHandler);
|
||||||
|
}
|
||||||
|
});
|
||||||
ContractManager.scheduledThreadPool.scheduleWithFixedDelay(
|
ContractManager.scheduledThreadPool.scheduleWithFixedDelay(
|
||||||
() -> {
|
() -> {
|
||||||
try {
|
try {
|
||||||
@ -110,19 +116,6 @@ public class NetworkManager {
|
|||||||
TimeUnit.SECONDS);
|
TimeUnit.SECONDS);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void setBootstrap(Bootstrap b) {
|
|
||||||
EventLoopGroup group = new NioEventLoopGroup();
|
|
||||||
b.group(group);
|
|
||||||
b.channel(NioSocketChannel.class)
|
|
||||||
.handler(
|
|
||||||
new ChannelInitializer<SocketChannel>() {
|
|
||||||
@Override
|
|
||||||
protected void initChannel(SocketChannel ch) {
|
|
||||||
ChannelPipeline p = ch.pipeline();
|
|
||||||
p.addLast(new DelimiterCodec()).addLast(nodeCenterClientHandler);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
private void createTCPServer(int port, EventLoopGroup workerGroup) {
|
private void createTCPServer(int port, EventLoopGroup workerGroup) {
|
||||||
try {
|
try {
|
||||||
@ -310,8 +303,8 @@ public class NetworkManager {
|
|||||||
|
|
||||||
public void waitForNodeCenterConnected() {
|
public void waitForNodeCenterConnected() {
|
||||||
for (int i = 0;
|
for (int i = 0;
|
||||||
i < 10 && null != nodeCenterClientHandler && !nodeCenterClientHandler.isConnected();
|
i < 10 && null != nodeCenterClientHandler && !nodeCenterClientHandler.isConnected();
|
||||||
i++) {
|
i++) {
|
||||||
try {
|
try {
|
||||||
Thread.sleep(200);
|
Thread.sleep(200);
|
||||||
} catch (InterruptedException e) {
|
} catch (InterruptedException e) {
|
||||||
|
@ -5,7 +5,7 @@ import org.bdware.server.action.ActionExecutor;
|
|||||||
import org.bdware.server.http.CMHttpHandler;
|
import org.bdware.server.http.CMHttpHandler;
|
||||||
import org.bdware.server.permission.Permission;
|
import org.bdware.server.permission.Permission;
|
||||||
import org.bdware.server.permission.Role;
|
import org.bdware.server.permission.Role;
|
||||||
import org.bdware.server.tcp.MasterClientFrameHandler;
|
import org.bdware.server.tcp.TCPClientFrameHandler;
|
||||||
import org.bdware.server.tcp.TCPServerFrameHandler;
|
import org.bdware.server.tcp.TCPServerFrameHandler;
|
||||||
import org.bdware.server.ws.ContractManagerFrameHandler;
|
import org.bdware.server.ws.ContractManagerFrameHandler;
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
@ -21,7 +21,7 @@ public class PermissionHelper {
|
|||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void compareClientAndServer() {
|
public void compareClientAndServer() {
|
||||||
MasterClientFrameHandler h = new MasterClientFrameHandler("abc");
|
TCPClientFrameHandler h = new TCPClientFrameHandler("abc");
|
||||||
Map<String, ActionExecutor.Pair<Method, Object>> handlers = h.ae.getHandlers();
|
Map<String, ActionExecutor.Pair<Method, Object>> handlers = h.ae.getHandlers();
|
||||||
List<Line> lines = parseWithClzName(handlers);
|
List<Line> lines = parseWithClzName(handlers);
|
||||||
TCPServerFrameHandler h2 = new TCPServerFrameHandler();
|
TCPServerFrameHandler h2 = new TCPServerFrameHandler();
|
||||||
@ -88,7 +88,7 @@ public class PermissionHelper {
|
|||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void listMasterClientAction() {
|
public void listMasterClientAction() {
|
||||||
MasterClientFrameHandler handler = new MasterClientFrameHandler("dd");
|
TCPClientFrameHandler handler = new TCPClientFrameHandler("dd");
|
||||||
parse(handler.ae.getHandlers(), false);
|
parse(handler.ae.getHandlers(), false);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user