mirror of
https://gitee.com/BDWare/agent-backend
synced 2025-01-10 01:44:14 +00:00
fix sigar dynamiclib missing
fix netty dynamiclib missing fix BCOManager
This commit is contained in:
parent
8fa064ee8a
commit
e76865fb09
13
build.gradle
13
build.gradle
@ -36,16 +36,21 @@ dependencies {
|
|||||||
implementation project(":front-base")
|
implementation project(":front-base")
|
||||||
implementation project(":consistency-sdk")
|
implementation project(":consistency-sdk")
|
||||||
implementation 'io.prometheus:simpleclient_httpserver:0.12.0'
|
implementation 'io.prometheus:simpleclient_httpserver:0.12.0'
|
||||||
implementation 'org.knowhowlab.osgi:sigar:1.6.5_01'
|
implementation 'org.hyperic.sigar:sigar:1.6.4'
|
||||||
implementation 'io.grpc:grpc-all:1.43.1'
|
implementation 'io.grpc:grpc-all:1.43.1'
|
||||||
implementation 'org.apache.velocity:velocity-engine-core:2.3'
|
implementation 'org.apache.velocity:velocity-engine-core:2.3'
|
||||||
implementation 'com.nimbusds:nimbus-jose-jwt:9.10'
|
implementation 'com.nimbusds:nimbus-jose-jwt:9.10'
|
||||||
implementation 'org.bdware.doip:doip-sdk:1.3.8'
|
implementation 'org.bdware.doip:doip-sdk:1.3.8'
|
||||||
implementation 'org.bdware.doip:doip-audit-tool:1.1.9'
|
implementation 'org.bdware.doip:doip-audit-tool:1.2.0'
|
||||||
implementation 'org.bdware.doip:bdosclient:0.0.1'
|
implementation 'org.bdware.doip:bdosclient:0.0.2'
|
||||||
implementation fileTree(dir: 'lib', include: '*.jar')
|
implementation fileTree(dir: 'lib', include: '*.jar')
|
||||||
testImplementation 'junit:junit:4.13.2'
|
testImplementation 'junit:junit:4.13.2'
|
||||||
implementation group: 'io.netty', name: 'netty-tcnative-boringssl-static', version: '2.0.50.Final'
|
implementation 'io.netty:netty-tcnative-boringssl-static:2.0.59.Final'
|
||||||
|
implementation 'io.netty:netty-tcnative-boringssl-static:2.0.59.Final-linux-aarch_64-fedora'
|
||||||
|
// implementation 'io.netty:netty-tcnative-boringssl-static:2.0.59.Final'
|
||||||
|
// implementation 'io.netty:netty-tcnative-boringssl-static:2.0.59.Final'
|
||||||
|
// implementation 'io.netty:netty-tcnative-boringssl-static:2.0.59.Final'
|
||||||
|
// implementation 'io.netty:netty-tcnative-boringssl-static:2.0.59.Final'
|
||||||
}
|
}
|
||||||
|
|
||||||
compileJava {
|
compileJava {
|
||||||
|
BIN
dynamicLibrary/libnetty_tcnative_linux_aarch_64.so
Normal file
BIN
dynamicLibrary/libnetty_tcnative_linux_aarch_64.so
Normal file
Binary file not shown.
BIN
dynamicLibrary/libnetty_tcnative_linux_x86_64.so
Normal file
BIN
dynamicLibrary/libnetty_tcnative_linux_x86_64.so
Normal file
Binary file not shown.
BIN
dynamicLibrary/libsigar-aarch64-linux.so
Normal file
BIN
dynamicLibrary/libsigar-aarch64-linux.so
Normal file
Binary file not shown.
Binary file not shown.
Binary file not shown.
@ -256,7 +256,6 @@ public class CMHttpServer {
|
|||||||
|
|
||||||
cmdConf.parseArgs(args);
|
cmdConf.parseArgs(args);
|
||||||
configServer(cmdConf);
|
configServer(cmdConf);
|
||||||
|
|
||||||
// check default key pair
|
// check default key pair
|
||||||
File keyFile = new File("manager.key");
|
File keyFile = new File("manager.key");
|
||||||
if (keyFile.exists()) {
|
if (keyFile.exists()) {
|
||||||
@ -282,7 +281,6 @@ public class CMHttpServer {
|
|||||||
} catch (IOException ignored) {
|
} catch (IOException ignored) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
GlobalConf.initIpPort(cmdConf.ip + ":" + cmdConf.servicePort);
|
GlobalConf.initIpPort(cmdConf.ip + ":" + cmdConf.servicePort);
|
||||||
GlobalConf.initMasterAddress(cmdConf.ip + ":" + (cmdConf.servicePort + 1));
|
GlobalConf.initMasterAddress(cmdConf.ip + ":" + (cmdConf.servicePort + 1));
|
||||||
start(cmdConf.servicePort);
|
start(cmdConf.servicePort);
|
||||||
@ -291,8 +289,6 @@ public class CMHttpServer {
|
|||||||
public static void start(int port) throws IOException {
|
public static void start(int port) throws IOException {
|
||||||
LOGGER.info("start server at:" + port);
|
LOGGER.info("start server at:" + port);
|
||||||
LOGGER.debug("dir:" + new File("./").getAbsolutePath());
|
LOGGER.debug("dir:" + new File("./").getAbsolutePath());
|
||||||
|
|
||||||
|
|
||||||
new CMHttpServer(port).start();
|
new CMHttpServer(port).start();
|
||||||
//never reach here!!
|
//never reach here!!
|
||||||
}
|
}
|
||||||
|
@ -81,16 +81,8 @@ public class GlobalConf {
|
|||||||
|
|
||||||
try {
|
try {
|
||||||
String dbName = CMTables.ConfigDB.toString();
|
String dbName = CMTables.ConfigDB.toString();
|
||||||
Class<?> clz = com.sleepycat.je.utilint.Tracer.class;
|
|
||||||
URL uri = clz.getClassLoader().getResource("com/sleepycat/je/utilint/Tracer.class");
|
|
||||||
LOGGER.debug(null == uri ? "uri is null!" : uri.getPath());
|
|
||||||
clz = com.sleepycat.je.log.FileHeader.class;
|
|
||||||
uri = clz.getClassLoader().getResource("com/sleepycat/je/log/FileHeader.class");
|
|
||||||
LOGGER.debug(null == uri ? "uri is null!" : uri.getPath());
|
|
||||||
|
|
||||||
if (!KeyValueDBUtil.instance.getKeys(dbName).contains("hasInited")) {
|
if (!KeyValueDBUtil.instance.getKeys(dbName).contains("hasInited")) {
|
||||||
KeyValueDBUtil.instance.setValue(dbName, "hasInited", "true");
|
KeyValueDBUtil.instance.setValue(dbName, "hasInited", "true");
|
||||||
|
|
||||||
KeyValueDBUtil.instance.setValue(
|
KeyValueDBUtil.instance.setValue(
|
||||||
dbName, "projectDir", new File("./BDWareProjectDir/").getAbsolutePath());
|
dbName, "projectDir", new File("./BDWareProjectDir/").getAbsolutePath());
|
||||||
KeyValueDBUtil.instance.setValue(
|
KeyValueDBUtil.instance.setValue(
|
||||||
@ -140,7 +132,7 @@ public class GlobalConf {
|
|||||||
KeyValueDBUtil.instance.setValue(dbName, "nodeName", deviceName.substring(0, 10));
|
KeyValueDBUtil.instance.setValue(dbName, "nodeName", deviceName.substring(0, 10));
|
||||||
KeyValueDBUtil.instance.setValue(dbName, "masterAddress", "null");
|
KeyValueDBUtil.instance.setValue(dbName, "masterAddress", "null");
|
||||||
KeyValueDBUtil.instance.setValue(dbName, "ipPort", "null");
|
KeyValueDBUtil.instance.setValue(dbName, "ipPort", "null");
|
||||||
KeyValueDBUtil.instance.setValue(dbName, "nodeCenter", "ws://127.0.0.1:18002");
|
KeyValueDBUtil.instance.setValue(dbName, "nodeCenter", "ws://127.0.0.1:18005");
|
||||||
KeyValueDBUtil.instance.setValue(
|
KeyValueDBUtil.instance.setValue(
|
||||||
dbName,
|
dbName,
|
||||||
"datachainConf",
|
"datachainConf",
|
||||||
@ -178,6 +170,7 @@ public class GlobalConf {
|
|||||||
loadDOAConfig(conf.doaConf, KeyValueDBUtil.instance.getValue(dbName, "doipConfig"));
|
loadDOAConfig(conf.doaConf, KeyValueDBUtil.instance.getValue(dbName, "doipConfig"));
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
LOGGER.error(e.getMessage());
|
LOGGER.error(e.getMessage());
|
||||||
|
e.printStackTrace();
|
||||||
LOGGER.debug(ExceptionUtil.exceptionToString(e));
|
LOGGER.debug(ExceptionUtil.exceptionToString(e));
|
||||||
}
|
}
|
||||||
// verifyLicence(conf);
|
// verifyLicence(conf);
|
||||||
|
@ -11,33 +11,40 @@ import org.bdware.doip.audit.client.AuditIrpClient;
|
|||||||
import org.bdware.doip.audit.writer.AuditType;
|
import org.bdware.doip.audit.writer.AuditType;
|
||||||
import org.bdware.doip.codec.doipMessage.DoipMessage;
|
import org.bdware.doip.codec.doipMessage.DoipMessage;
|
||||||
import org.bdware.doip.endpoint.client.DoipMessageCallback;
|
import org.bdware.doip.endpoint.client.DoipMessageCallback;
|
||||||
import org.bdware.irp.client.IrpClient;
|
|
||||||
import org.bdware.sc.db.CMTables;
|
|
||||||
import org.bdware.sc.db.KeyValueDBUtil;
|
|
||||||
import org.bdware.server.GlobalConf;
|
import org.bdware.server.GlobalConf;
|
||||||
import org.zz.gmhelper.SM2KeyPair;
|
import org.zz.gmhelper.SM2KeyPair;
|
||||||
|
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
import java.util.concurrent.atomic.AtomicInteger;
|
|
||||||
|
|
||||||
public class BCOManager {
|
public class BCOManager {
|
||||||
|
private final String codeRepoDoid;
|
||||||
|
private final String routerURI;
|
||||||
|
private final SM2KeyPair keyPair;
|
||||||
CodeRepoClient client;
|
CodeRepoClient client;
|
||||||
File bcodir;
|
File bcodir;
|
||||||
IrpClient irpClient;
|
|
||||||
static Logger LOGGER = LogManager.getLogger(BCOManager.class);
|
static Logger LOGGER = LogManager.getLogger(BCOManager.class);
|
||||||
|
|
||||||
public BCOManager(String doid, File bcoDir, IrpClient irpClient, SM2KeyPair keyPair) {
|
public BCOManager(String doid, File bcoDir, String routerURI, SM2KeyPair keyPair) {
|
||||||
String codeRepoDoid = CodeRepoClient.getDefaultCodeRepo(doid);
|
|
||||||
this.irpClient = irpClient;
|
|
||||||
this.bcodir = bcoDir;
|
this.bcodir = bcoDir;
|
||||||
|
this.codeRepoDoid = CodeRepoClient.getDefaultCodeRepo(doid);
|
||||||
|
this.routerURI = routerURI;
|
||||||
|
this.keyPair = keyPair;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String download(String bCoId) {
|
||||||
|
if (client == null) {
|
||||||
|
EndpointConfig config = new EndpointConfig();
|
||||||
|
config.routerURI = GlobalConf.instance.doaConf.lhsAddress;
|
||||||
|
config.auditType = AuditType.None;
|
||||||
|
AuditIrpClient irpClient = new AuditIrpClient(codeRepoDoid, config);
|
||||||
client = new CodeRepoClient(codeRepoDoid, irpClient, keyPair);
|
client = new CodeRepoClient(codeRepoDoid, irpClient, keyPair);
|
||||||
}
|
}
|
||||||
public String download(String bCoId) {
|
|
||||||
YPKInfo ypkInfo = new YPKInfo();
|
YPKInfo ypkInfo = new YPKInfo();
|
||||||
client.retrieveBCO(bCoId, new DoipMessageCallback() {
|
client.retrieveBCO(bCoId, new DoipMessageCallback() {
|
||||||
@Override
|
@Override
|
||||||
public void onResult(DoipMessage doipMessage) {
|
public void onResult(DoipMessage doipMessage) {
|
||||||
String body = doipMessage.body.getDataAsJsonString();
|
String body = doipMessage.body.getDataAsJsonString();
|
||||||
|
LOGGER.info("Retrieve " + bCoId + " Result:" + body);
|
||||||
YPKInfo parsed = new Gson().fromJson(body, YPKInfo.class);
|
YPKInfo parsed = new Gson().fromJson(body, YPKInfo.class);
|
||||||
if (parsed != null && parsed.md5 != null && parsed.status == UploadingStatus.Finished) {
|
if (parsed != null && parsed.md5 != null && parsed.status == UploadingStatus.Finished) {
|
||||||
ypkInfo.copyFrom(parsed);
|
ypkInfo.copyFrom(parsed);
|
||||||
@ -54,13 +61,18 @@ public class BCOManager {
|
|||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
LOGGER.info("Download:" + new Gson().toJson(ypkInfo));
|
||||||
|
|
||||||
if (ypkInfo.status == UploadingStatus.Finished) {
|
if (ypkInfo.status == UploadingStatus.Finished) {
|
||||||
File target = getYpkFile(ypkInfo);
|
File target = getYpkFile(ypkInfo);
|
||||||
if (target.exists() && (client.calFileMd5(target.getAbsolutePath()) + ".ypk").equals(target.getName()))
|
if (target.exists() && (client.calFileMd5(target.getAbsolutePath()) + ".ypk").equals(target.getName()))
|
||||||
return target.getAbsolutePath();
|
return target.getAbsolutePath();
|
||||||
DownloadProgressChecker checker = new DownloadProgressChecker();
|
DownloadProgressChecker checker = new DownloadProgressChecker();
|
||||||
client.downloadYPK(bCoId, checker, target);
|
client.downloadYPK(bCoId, checker, target);
|
||||||
|
LOGGER.info("start Download:" + new Gson().toJson(ypkInfo));
|
||||||
checker.waitForResult(30000);
|
checker.waitForResult(30000);
|
||||||
|
LOGGER.info("checker:" + checker.isSuccess);
|
||||||
|
|
||||||
if (checker.isSuccess)
|
if (checker.isSuccess)
|
||||||
return target.getAbsolutePath();
|
return target.getAbsolutePath();
|
||||||
}
|
}
|
||||||
@ -97,6 +109,7 @@ public class BCOManager {
|
|||||||
synchronized (this) {
|
synchronized (this) {
|
||||||
this.notify();
|
this.notify();
|
||||||
}
|
}
|
||||||
|
LOGGER.info("[Download error]" + s + " doipMessage:" + doipMessage.body.getDataAsJsonString());
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -8,7 +8,6 @@ import io.netty.channel.ChannelHandler;
|
|||||||
import org.apache.logging.log4j.LogManager;
|
import org.apache.logging.log4j.LogManager;
|
||||||
import org.apache.logging.log4j.Logger;
|
import org.apache.logging.log4j.Logger;
|
||||||
import org.bdware.doip.audit.EndpointConfig;
|
import org.bdware.doip.audit.EndpointConfig;
|
||||||
import org.bdware.doip.audit.client.AuditIrpClient;
|
|
||||||
import org.bdware.doip.audit.server.DefaultRepoHandlerInjector;
|
import org.bdware.doip.audit.server.DefaultRepoHandlerInjector;
|
||||||
import org.bdware.doip.codec.digitalObject.DigitalObject;
|
import org.bdware.doip.codec.digitalObject.DigitalObject;
|
||||||
import org.bdware.doip.codec.digitalObject.DoType;
|
import org.bdware.doip.codec.digitalObject.DoType;
|
||||||
@ -51,15 +50,9 @@ public class ContractRepositoryHandler extends RepositoryHandlerBase implements
|
|||||||
super(info);
|
super(info);
|
||||||
GlobalConf.DOAConf doaConf = GlobalConf.instance.doaConf;
|
GlobalConf.DOAConf doaConf = GlobalConf.instance.doaConf;
|
||||||
String bcoDir = GlobalConf.instance.bcoDir;
|
String bcoDir = GlobalConf.instance.bcoDir;
|
||||||
EndpointConfig config = new EndpointConfig();
|
bcoManager = new BCOManager(doaConf.repoDoid, new File(bcoDir), doaConf.lhsAddress, GlobalConf.instance.keyPair);
|
||||||
config.routerURI = doaConf.lhsAddress;
|
|
||||||
AuditIrpClient client = new AuditIrpClient(config);
|
|
||||||
bcoManager = new BCOManager(doaConf.repoDoid, new File(bcoDir), client, GlobalConf.instance.keyPair);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
CMActions cmActions = new CMActions();
|
|
||||||
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public DoipMessage handleHello(DoipMessage doipMessage) {
|
public DoipMessage handleHello(DoipMessage doipMessage) {
|
||||||
return replyDoipServiceInfo(doipMessage);
|
return replyDoipServiceInfo(doipMessage);
|
||||||
@ -97,9 +90,9 @@ public class ContractRepositoryHandler extends RepositoryHandlerBase implements
|
|||||||
e.printStackTrace(new PrintStream(bo));
|
e.printStackTrace(new PrintStream(bo));
|
||||||
return replyStringWithStatus(doipMessage, "exception:" + new String(bo.toByteArray()), DoipResponseCode.Invalid);
|
return replyStringWithStatus(doipMessage, "exception:" + new String(bo.toByteArray()), DoipResponseCode.Invalid);
|
||||||
}
|
}
|
||||||
DoipMessage[] content = new DoipMessage[1];
|
|
||||||
digitalObject.attributes.addProperty("verifiedPubKey", doipMessage.credential.getSigner());
|
digitalObject.attributes.addProperty("verifiedPubKey", doipMessage.credential.getSigner());
|
||||||
String path = null;
|
String path = null;
|
||||||
|
LOGGER.info("create BDO, bCoId:" + digitalObject.attributes.get("bCoId").getAsString());
|
||||||
if (digitalObject.attributes.has("bCoId"))
|
if (digitalObject.attributes.has("bCoId"))
|
||||||
path = bcoManager.download(digitalObject.attributes.get("bCoId").getAsString());
|
path = bcoManager.download(digitalObject.attributes.get("bCoId").getAsString());
|
||||||
|
|
||||||
|
@ -1,5 +1,6 @@
|
|||||||
package org.bdware.server.doip;
|
package org.bdware.server.doip;
|
||||||
|
|
||||||
|
import com.google.gson.Gson;
|
||||||
import org.apache.logging.log4j.LogManager;
|
import org.apache.logging.log4j.LogManager;
|
||||||
import org.apache.logging.log4j.Logger;
|
import org.apache.logging.log4j.Logger;
|
||||||
import org.bdware.doip.audit.EndpointConfig;
|
import org.bdware.doip.audit.EndpointConfig;
|
||||||
@ -19,8 +20,8 @@ public class ContractRepositoryMain {
|
|||||||
|
|
||||||
public static void start() {
|
public static void start() {
|
||||||
try {
|
try {
|
||||||
|
LOGGER.info("DOIPServer, start" + new Gson().toJson(GlobalConf.instance.doaConf));
|
||||||
String url = GlobalConf.instance.doaConf.doipAddress;
|
String url = GlobalConf.instance.doaConf.doipAddress;
|
||||||
LOGGER.info("DOIPServer start:" + url);
|
|
||||||
if (url == null || GlobalConf.instance.doaConf.repoDoid.isEmpty()) {
|
if (url == null || GlobalConf.instance.doaConf.repoDoid.isEmpty()) {
|
||||||
LOGGER.warn("missing args, failed to start! url:" + url + " doid:" + GlobalConf.instance.doaConf.repoDoid);
|
LOGGER.warn("missing args, failed to start! url:" + url + " doid:" + GlobalConf.instance.doaConf.repoDoid);
|
||||||
return;
|
return;
|
||||||
@ -37,7 +38,7 @@ public class ContractRepositoryMain {
|
|||||||
config.auditType = AuditType.None;
|
config.auditType = AuditType.None;
|
||||||
config.routerURI = GlobalConf.instance.doaConf.lhsAddress;
|
config.routerURI = GlobalConf.instance.doaConf.lhsAddress;
|
||||||
config.repoName = GlobalConf.instance.doaConf.repoName;
|
config.repoName = GlobalConf.instance.doaConf.repoName;
|
||||||
currentServer = new AuditDoipServer(config);
|
currentServer = new AuditDoipServer(config, info);
|
||||||
currentServer.setRepositoryHandler(new ContractRepositoryHandler(info));
|
currentServer.setRepositoryHandler(new ContractRepositoryHandler(info));
|
||||||
currentServer.start();
|
currentServer.start();
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
|
@ -25,7 +25,7 @@ public class BCOManagerTest {
|
|||||||
// config.privateKey = key.getPrivateKeyStr();
|
// config.privateKey = key.getPrivateKeyStr();
|
||||||
// config.publicKey = key.getPublicKeyStr();
|
// config.publicKey = key.getPublicKeyStr();
|
||||||
|
|
||||||
this.bcoManager = new BCOManager("bdtest/CodeRepository", new File("./BDWareProjectDir/bco"), client, key);
|
this.bcoManager = new BCOManager("bdtest/CodeRepository", new File("./BDWareProjectDir/bco"), config.routerURI, key);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
Loading…
Reference in New Issue
Block a user