mirror of
https://gitee.com/BDWare/agent-backend
synced 2025-01-10 01:44:14 +00:00
feat: support createParam
feat: docker script
This commit is contained in:
parent
0a24986907
commit
5a4fdb8a13
@ -19,7 +19,9 @@
|
||||
"textFileSuffixes":".yjs,.json,.txt,.css,.js,.html,.md,.conf,.csv",
|
||||
"withBdledgerClient":"./runnable/bdledger_mac",
|
||||
"withBdledgerServer":false,
|
||||
"consistencyPlugins": "./libs/custom-plugin.jar"
|
||||
"consistencyPlugins": "./libs/custom-plugin.jar",
|
||||
"startContract": [],
|
||||
"datachainConf": "021.node.internetapi.cn:21121"
|
||||
}
|
||||
```
|
||||
## consistencyPlugins 配置
|
||||
@ -36,3 +38,28 @@
|
||||
2. clientToAgentPlugins: client -> cluster 包括MasterClientFrameHandler
|
||||
3. clientToClusterPlugins:[], client -> NodeCenterClientHandler
|
||||
4. tcpPlugins:tcp 包括TcpserverFrameHandler
|
||||
|
||||
## startContract配置说明
|
||||
其中startConfig.json为json数组结构,格式如下:
|
||||
```json
|
||||
[
|
||||
{
|
||||
"path": "./BDWareProjectDir/publicCompiled/xxx.ypk",
|
||||
"owner": "",
|
||||
"createParam": {}
|
||||
},
|
||||
{
|
||||
...
|
||||
}
|
||||
]
|
||||
path为必填配置项。表示启动的ypk的路径。
|
||||
owner为可选配置,不填时,使用NodeManger的key作为Owner。
|
||||
createParam为可选配置。表示合约的启动参数。
|
||||
```
|
||||
## datachainConf 配置说明
|
||||
1.针对Window Docker/Mac Docker
|
||||
可使用`"datachainConf":"host.docker.internal:2401"`进行配置。
|
||||
2.针对Linux Docker,可通过查看`docker 0`的网卡IP进行设置。
|
||||
如:`"datachainConf":"172.16.10.1:2401"`。
|
||||
3.如果是在同一dockercompose.yml下启动,可以使用:
|
||||
`"datachainConf":"bdledger:2401"`进行配置。
|
@ -1,5 +1,7 @@
|
||||
package org.bdware.server;
|
||||
|
||||
import com.google.gson.JsonElement;
|
||||
import com.google.gson.JsonObject;
|
||||
import io.netty.bootstrap.ServerBootstrap;
|
||||
import io.netty.buffer.PooledByteBufAllocator;
|
||||
import io.netty.channel.*;
|
||||
@ -137,7 +139,6 @@ public class CMHttpServer {
|
||||
TCPClientFrameHandler.clientToAgentPlugins = parseStrAsList(cmdConf.clientToAgentPlugins);
|
||||
NodeCenterClientHandler.clientToClusterPlugins = parseStrAsList(cmdConf.clientToClusterPlugins);
|
||||
org.bdware.units.tcp.TCPClientFrameHandler.tcpPlugins = parseStrAsList(cmdConf.tcpPlugins);
|
||||
|
||||
if (!cmdConf.debug.isEmpty()) {
|
||||
try {
|
||||
String[] classes = cmdConf.debug.split(",");
|
||||
@ -153,26 +154,41 @@ public class CMHttpServer {
|
||||
LOGGER.warn(e.getMessage());
|
||||
}
|
||||
}
|
||||
if (cmdConf.overwrite) {
|
||||
cmdConf.write(CONFIG_PATH);
|
||||
}
|
||||
if (cmdConf.startContract != null && cmdConf.startContract.length() > 0) {
|
||||
|
||||
if (cmdConf.startContract != null && cmdConf.startContract.size() > 0) {
|
||||
ContractManager.scheduledThreadPool.schedule(
|
||||
() -> {
|
||||
String[] paths = cmdConf.startContract.split(",");
|
||||
for (String path : paths) {
|
||||
try {
|
||||
for (JsonElement je : cmdConf.startContract) {
|
||||
JsonObject jo = je.getAsJsonObject();
|
||||
String path = jo.get("path").getAsString();
|
||||
File f = new File(path);
|
||||
if (!f.getName().endsWith(".ypk") || !f.exists())
|
||||
continue;
|
||||
Contract c = new Contract();
|
||||
c.setScript(f.getAbsolutePath());
|
||||
c.setType(ContractExecType.Sole);
|
||||
if (jo.has("owner"))
|
||||
c.setOwner(jo.get("owner").getAsString());
|
||||
else
|
||||
c.setOwner(UserManagerAction.getNodeManager());
|
||||
if (jo.has("createParam"))
|
||||
c.setCreateParam(jo.get("createParam"));
|
||||
ContractManager.instance.startContract(c);
|
||||
}
|
||||
} catch (Exception e) {
|
||||
e.printStackTrace();
|
||||
}
|
||||
},
|
||||
10, TimeUnit.SECONDS);
|
||||
}
|
||||
if (cmdConf.datachainConf!=null){
|
||||
GlobalConf.resetDataChain(cmdConf.datachainConf);
|
||||
}
|
||||
if (cmdConf.overwrite) {
|
||||
cmdConf.write(CONFIG_PATH);
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
private static String[] parseStrAsList(String str) {
|
||||
|
@ -47,7 +47,6 @@ public class CongestionControl {
|
||||
jo.addProperty("slaveConn", slaveCounter.get());
|
||||
jo.addProperty("slaveQueue", masterProxyLoad.get());
|
||||
jo.addProperty("masterQueue", masterServerLoad.get());
|
||||
|
||||
jo.addProperty("maxConnCount", maxHttpConnCount);
|
||||
jo.addProperty("httpMaxQueue", currHttpMax);
|
||||
jo.addProperty("slaveMaxQueue", maxMasterProxyLoad);
|
||||
|
@ -815,7 +815,7 @@ public class GRPCPool implements ChainOpener {
|
||||
logType.put("branch", "branch log failure");
|
||||
}
|
||||
} else if (info.equals("Result")) {
|
||||
s = jo.get("result").getAsString();
|
||||
s = jo.get("result").toString();
|
||||
s = JsonUtil.toJson(s);
|
||||
if (s.length() > 2) {
|
||||
s = s.substring(1, s.length() - 1);
|
||||
|
@ -733,7 +733,9 @@ public class CMActions implements OnHashCallback {
|
||||
c.setOwner(GlobalConf.instance.keyPair.getPublicKeyStr());
|
||||
c.doSignature(GlobalConf.instance.keyPair);
|
||||
}
|
||||
|
||||
if (args.has("createParam")) {
|
||||
c.setCreateParam(args.get("createParam"));
|
||||
}
|
||||
// if (!c.verifySignature()) {
|
||||
// ret.put("data", "verify failed");
|
||||
// resultCallback.onResult(gson.toJson(ret));
|
||||
@ -831,6 +833,9 @@ public class CMActions implements OnHashCallback {
|
||||
c.setOwner(GlobalConf.instance.keyPair.getPublicKeyStr());
|
||||
c.doSignature(GlobalConf.instance.keyPair);
|
||||
}
|
||||
if (args.has("createParam")) {
|
||||
c.setCreateParam(args.get("createParam"));
|
||||
}
|
||||
// 上面那些。。有空再整理一下
|
||||
c.setDebug(false);
|
||||
c.setOwner(args.get("verifiedPubKey").getAsString());
|
||||
@ -956,6 +961,9 @@ public class CMActions implements OnHashCallback {
|
||||
}
|
||||
c.setDebug(true);
|
||||
System.out.println(c.isDebug());
|
||||
if (args.has("createParam")) {
|
||||
c.setCreateParam(args.get("createParam"));
|
||||
}
|
||||
// 上面那些。。有空再整理一下
|
||||
c.setOwner(args.get("verifiedPubKey").getAsString());
|
||||
|
||||
@ -1266,6 +1274,53 @@ public class CMActions implements OnHashCallback {
|
||||
}
|
||||
}
|
||||
|
||||
@Action(userPermission = 1L << 26, async = true)
|
||||
public void restartContractProcess(JsonObject args, ResultCallback resultCallback) {
|
||||
LOGGER.debug("[CMActions] killContractProcess : " + args.has("verifiedPubKey"));
|
||||
if (args.has("verifiedPubKey") && (args.has("id") || args.has("name"))) {
|
||||
ContractRequest rc = new ContractRequest();
|
||||
long s = System.currentTimeMillis();
|
||||
if (args.has("id")) {
|
||||
// stop unit contract using contract name
|
||||
rc.setContractID(args.get("id").getAsString());
|
||||
} else {
|
||||
// stop unit contract using contract name
|
||||
rc.setContractID(args.get("name").getAsString());
|
||||
}
|
||||
ContractMeta meta = manager.statusRecorder.getContractMeta(rc.getContractID());
|
||||
Contract contract = meta.contract;
|
||||
killContractProcess(args, resultCallback);
|
||||
manager.startContractAndRedirect(contract,System.out);
|
||||
String data = manager.listContractsWithOwner(
|
||||
args.get("verifiedPubKey").getAsString(),
|
||||
null,
|
||||
args.has("filters") ? args.get("filters").getAsInt() : 0);
|
||||
ReplyUtil.simpleReply(resultCallback, "onListContractProcess", data);
|
||||
}else {
|
||||
ReplyUtil.simpleReply(resultCallback, "onRestartContractProcess", "Failed: Illegal parameters");
|
||||
}
|
||||
}
|
||||
|
||||
@Action(userPermission = 1L << 26, async = true)
|
||||
public void pruneKilledContract(JsonObject args, ResultCallback resultCallback) {
|
||||
Map<String, ContractMeta> map = CMActions.manager.statusRecorder.getStatus();
|
||||
LOGGER.info("pruneKilledContract!!!");
|
||||
Set<ContractMeta> toRemove = new HashSet<>();
|
||||
for (ContractMeta meta : map.values()) {
|
||||
if (meta.getStatus().equals(ContractStatusEnum.KILLED))
|
||||
toRemove.add(meta);
|
||||
}
|
||||
LOGGER.info("pruneKilledContract!!! size:" + toRemove.size());
|
||||
for (ContractMeta key : toRemove) {
|
||||
CMActions.manager.statusRecorder.remove(key);
|
||||
MultiContractMeta multiMeta = CMActions.manager.multiContractRecorder.getMultiContractMeta(key.getID());
|
||||
CMActions.manager.multiContractRecorder.remove(multiMeta);
|
||||
}
|
||||
resultCallback.onResult("size:" + toRemove.size());
|
||||
|
||||
}
|
||||
|
||||
|
||||
@Action(userPermission = 1L << 26, async = true)
|
||||
public void queryContractInstanceDOI(JsonObject args, ResultCallback resultCallback) {
|
||||
long s = System.currentTimeMillis();
|
||||
@ -1356,39 +1411,6 @@ public class CMActions implements OnHashCallback {
|
||||
resultCallback.onResult(r);
|
||||
}
|
||||
|
||||
@Action(async = true, userPermission = 1L << 26)
|
||||
public void startContractInTempZips(JsonObject args, ResultCallback resultCallback) {
|
||||
long start = System.currentTimeMillis();
|
||||
Contract c = new Contract();
|
||||
// c.setType(Type.Algorithm);
|
||||
c.setType(ContractExecType.Sole);
|
||||
String pubkey = args.get("owner").getAsString();
|
||||
// SCManagerServlet.registerCCCallback(json.getString("requestID"), this);
|
||||
Map<String, Object> r = new HashMap<>();
|
||||
r.put("action", "onStartContract");
|
||||
String path = args.get("path").getAsString();
|
||||
path =
|
||||
new File(new File(GlobalConf.instance.projectDir, "tempZips"), path)
|
||||
.getAbsolutePath();
|
||||
c.setScript(path);
|
||||
c.setSignature(args.get("signature").getAsString());
|
||||
c.setOwner(pubkey);
|
||||
if (!c.verifySignature()) {
|
||||
r.put("data", "verify failed");
|
||||
resultCallback.onResult(r);
|
||||
return;
|
||||
}
|
||||
r.put("data", manager.startContractAndRedirect(c, System.out));
|
||||
r.put("cid", c.getID());
|
||||
r.put("executeTime", System.currentTimeMillis() - start);
|
||||
resultCallback.onResult(r);
|
||||
|
||||
if (args.has("dumpPeriod")) {
|
||||
LOGGER.debug("[CMActions]启动后设置dump周期" + args.get("dumpPeriod").getAsString());
|
||||
manager.changeDumpPeriod(c.getID(), args.get("dumpPeriod").getAsString());
|
||||
}
|
||||
}
|
||||
|
||||
@Action(userPermission = 1L << 26, async = true, httpAccess = false)
|
||||
public void killAllContract(JsonObject args, ResultCallback resultCallback) {
|
||||
if (args.has("verifiedPubKey")) {
|
||||
|
@ -402,7 +402,6 @@ public class FileActions {
|
||||
}
|
||||
|
||||
public static void startIfManifestDetected(File targetDir) {
|
||||
|
||||
try {
|
||||
String contractName = targetDir.getName();
|
||||
String owner = targetDir.getParentFile().getName();
|
||||
|
@ -92,6 +92,8 @@ public class MasterWSAction {
|
||||
} else if (args.has("projectName")) {
|
||||
contract.setScript("/" + args.get("projectName").getAsString());
|
||||
}
|
||||
if (args.has("createParam"))
|
||||
contract.setCreateParam(args.get("createParam"));
|
||||
// contract.setScript("/" + args.get("projectName").getAsString() + "/manifest.json");
|
||||
|
||||
// String toVerify =
|
||||
|
@ -176,24 +176,7 @@ public class TemporyTestAction {
|
||||
resultCallback.onResult(jo.toString());
|
||||
}
|
||||
|
||||
@Action(async = true)
|
||||
public void pruneKilledContract(JsonObject args, ResultCallback resultCallback) {
|
||||
Map<String, ContractMeta> map = CMActions.manager.statusRecorder.getStatus();
|
||||
LOGGER.info("pruneKilledContract!!!");
|
||||
Set<ContractMeta> toRemove = new HashSet<>();
|
||||
for (ContractMeta meta : map.values()) {
|
||||
if (meta.getStatus().equals(ContractStatusEnum.KILLED))
|
||||
toRemove.add(meta);
|
||||
}
|
||||
LOGGER.info("pruneKilledContract!!! size:" + toRemove.size());
|
||||
for (ContractMeta key : toRemove) {
|
||||
CMActions.manager.statusRecorder.remove(key);
|
||||
MultiContractMeta multiMeta = CMActions.manager.multiContractRecorder.getMultiContractMeta(key.getID());
|
||||
CMActions.manager.multiContractRecorder.remove(multiMeta);
|
||||
}
|
||||
resultCallback.onResult("size:" + toRemove.size());
|
||||
|
||||
}
|
||||
|
||||
@Action(async = true)
|
||||
public void reconnectPort(JsonObject args, ResultCallback resultCallback) {
|
||||
|
Loading…
Reference in New Issue
Block a user