mirror of
https://gitee.com/BDWare/agent-backend
synced 2025-01-10 01:44:14 +00:00
optimize receive file
This commit is contained in:
parent
bc4eb8b828
commit
9f30c938da
@ -3,10 +3,7 @@ package org.bdware.server.action;
|
||||
import com.google.gson.JsonObject;
|
||||
import org.apache.logging.log4j.LogManager;
|
||||
import org.apache.logging.log4j.Logger;
|
||||
import org.bdware.sc.ContractClient;
|
||||
import org.bdware.sc.ContractManager;
|
||||
import org.bdware.sc.ContractMeta;
|
||||
import org.bdware.sc.ContractStatusEnum;
|
||||
import org.bdware.sc.*;
|
||||
import org.bdware.sc.bean.Contract;
|
||||
import org.bdware.sc.bean.ContractExecType;
|
||||
import org.bdware.sc.conn.ResultCallback;
|
||||
@ -179,8 +176,9 @@ public class TemporyTestAction {
|
||||
}
|
||||
|
||||
@Action(async = true)
|
||||
public void reconnectAll(JsonObject args, ResultCallback resultCallback) {
|
||||
ContractManager.instance.reconnectContractProcess();
|
||||
public void reconnectPort(JsonObject args, ResultCallback resultCallback) {
|
||||
ContractPort.PortVisitor reconnectVisitor = CMActions.manager.statusRecorder.getVisitor();
|
||||
reconnectVisitor.visit(args.get("port").getAsInt());
|
||||
String data = ContractManager.instance.listContractsWithOwner(
|
||||
args.get("owner").getAsString(), null, 0);
|
||||
JsonObject ret = new JsonObject();
|
||||
|
@ -40,7 +40,6 @@ public class NodeCenterClientController implements NodeCenterConn {
|
||||
private static final Logger LOGGER = LogManager.getLogger(NodeCenterClientController.class);
|
||||
public static SyncResult sync = new SyncResult();
|
||||
private static boolean startCheck = false;
|
||||
private final Map<String, FileOutputStream> fileMap;
|
||||
private final NetNeighbors neighbors;
|
||||
public Map<String, ResultCallback> distributeReqMap = new ConcurrentHashMap<>();
|
||||
// public NodeCenterClientController cmClientController;
|
||||
@ -48,9 +47,11 @@ public class NodeCenterClientController implements NodeCenterConn {
|
||||
NodeCenterClientHandler handler;
|
||||
// 合约contractID,master的公钥
|
||||
Map<String, String> contractID2PubKey = new ConcurrentHashMap<>();
|
||||
Deque<JsonObject> receiveQueue = new ArrayDeque<>();
|
||||
ReceiveFileThread receiveFileThread = new ReceiveFileThread();
|
||||
|
||||
public NodeCenterClientController(String nodeID) {
|
||||
this.fileMap = new HashMap<>();
|
||||
|
||||
this.nodeID = nodeID;
|
||||
this.neighbors = new NetNeighbors();
|
||||
}
|
||||
@ -518,65 +519,105 @@ public class NodeCenterClientController implements NodeCenterConn {
|
||||
queryNCRepoDOI(json, result);
|
||||
}
|
||||
|
||||
@Action(async = true)
|
||||
public void receiveProject(JsonObject args, final ResultCallback rc) {
|
||||
LOGGER.debug("position----7");
|
||||
|
||||
String fileName = args.get("fileName").getAsString();
|
||||
boolean isAppend = args.get("isAppend").getAsBoolean();
|
||||
boolean isDone = args.get("isDone").getAsBoolean();
|
||||
boolean isPrivate = args.get("isPrivate").getAsBoolean();
|
||||
class ReceiveFileThread extends Thread {
|
||||
private final Map<String, FileOutputStream> fileMap = new HashMap<>();
|
||||
|
||||
LOGGER.debug(
|
||||
String.format("isAppend=%b isDone=%b isPrivate=%b", isAppend, isDone, isPrivate));
|
||||
String path = GlobalConf.instance.publicCompiledDir;
|
||||
if (isPrivate && args.has("pubKey")) {
|
||||
path = GlobalConf.instance.privateCompiledDir + "/" + args.get("pubKey").getAsString();
|
||||
ReceiveFileThread() {
|
||||
super();
|
||||
this.start();
|
||||
}
|
||||
|
||||
File dir = new File(path);
|
||||
if (!dir.exists()) {
|
||||
LOGGER.debug("mkdir " + dir.getAbsoluteFile() + ": " + dir.mkdirs());
|
||||
}
|
||||
FileOutputStream fout = null;
|
||||
if (!isAppend) {
|
||||
try {
|
||||
fout = new FileOutputStream(new File(dir, fileName));
|
||||
fileMap.put(fileName, fout);
|
||||
} catch (FileNotFoundException e) {
|
||||
e.printStackTrace();
|
||||
public void run() {
|
||||
for (; ; ) {
|
||||
if (receiveQueue.size() > 0) {
|
||||
try {
|
||||
JsonObject jo = receiveQueue.poll();
|
||||
receiveProject(jo);
|
||||
} catch (Exception e) {
|
||||
e.printStackTrace();
|
||||
}
|
||||
} else {
|
||||
synchronized (ReceiveFileThread.this) {
|
||||
try {
|
||||
this.wait();
|
||||
} catch (InterruptedException e) {
|
||||
e.printStackTrace();
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
} else {
|
||||
fout = fileMap.get(fileName);
|
||||
|
||||
}
|
||||
if (isDone) {
|
||||
if (fout != null)
|
||||
|
||||
public void receiveProject(JsonObject args) {
|
||||
|
||||
String fileName = args.get("fileName").getAsString();
|
||||
boolean isAppend = args.get("isAppend").getAsBoolean();
|
||||
boolean isDone = args.get("isDone").getAsBoolean();
|
||||
boolean isPrivate = args.get("isPrivate").getAsBoolean();
|
||||
LOGGER.debug(
|
||||
String.format("isAppend=%b isDone=%b isPrivate=%b", isAppend, isDone, isPrivate));
|
||||
String path = GlobalConf.instance.publicCompiledDir;
|
||||
if (isPrivate && args.has("pubKey")) {
|
||||
path = GlobalConf.instance.privateCompiledDir + "/" + args.get("pubKey").getAsString();
|
||||
}
|
||||
File dir = new File(path);
|
||||
if (!dir.exists()) {
|
||||
LOGGER.debug("mkdir " + dir.getAbsoluteFile() + ": " + dir.mkdirs());
|
||||
}
|
||||
FileOutputStream fout = null;
|
||||
if (!isAppend) {
|
||||
try {
|
||||
fout.close();
|
||||
fileMap.remove(fileName);
|
||||
fout = new FileOutputStream(new File(dir, fileName));
|
||||
fileMap.put(fileName, fout);
|
||||
} catch (FileNotFoundException e) {
|
||||
e.printStackTrace();
|
||||
}
|
||||
} else {
|
||||
fout = fileMap.get(fileName);
|
||||
}
|
||||
if (isDone) {
|
||||
if (fout != null)
|
||||
try {
|
||||
fout.close();
|
||||
fileMap.remove(fileName);
|
||||
} catch (IOException e) {
|
||||
e.printStackTrace();
|
||||
}
|
||||
LOGGER.debug("receive finish.");
|
||||
Map<String, String> req = new HashMap<>();
|
||||
req.put("action", "onReceiveProject");
|
||||
req.put("requestID", args.get("requestID").getAsString());
|
||||
req.put("nodeID", nodeID);
|
||||
req.put("progress", "100");
|
||||
NetworkManager.instance.sendToNodeCenter(JsonUtil.toJson(req));
|
||||
} else {
|
||||
String data = args.get("data").getAsString();
|
||||
byte[] byteData = ByteUtil.decodeBASE64(data);
|
||||
try {
|
||||
if (null != fout && null != byteData) {
|
||||
fout.write(byteData);
|
||||
}
|
||||
} catch (IOException e) {
|
||||
e.printStackTrace();
|
||||
}
|
||||
LOGGER.debug("receive finish.");
|
||||
Map<String, String> req = new HashMap<>();
|
||||
req.put("action", "onReceiveProject");
|
||||
req.put("requestID", args.get("requestID").getAsString());
|
||||
req.put("nodeID", nodeID);
|
||||
req.put("progress", "100");
|
||||
rc.onResult(JsonUtil.toJson(req));
|
||||
} else {
|
||||
String data = args.get("data").getAsString();
|
||||
byte[] byteData = ByteUtil.decodeBASE64(data);
|
||||
try {
|
||||
if (null != fout && null != byteData) {
|
||||
fout.write(byteData);
|
||||
}
|
||||
} catch (IOException e) {
|
||||
e.printStackTrace();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@Action(async = false)
|
||||
public synchronized void receiveProject(JsonObject args, final ResultCallback rc) {
|
||||
try {
|
||||
receiveQueue.add(args);
|
||||
synchronized (receiveFileThread) {
|
||||
receiveFileThread.notify();
|
||||
}
|
||||
} catch (Exception e) {
|
||||
e.printStackTrace();
|
||||
}
|
||||
}
|
||||
|
||||
public void queryNCRepoDOI(JsonObject json, ResultCallback result) {
|
||||
LOGGER.debug("sendProject: position ---- 3");
|
||||
String projectName = json.get("projectName").getAsString();
|
||||
|
Loading…
Reference in New Issue
Block a user