0

我希望在多台机器上运行 Java 进程,每台机器都需要启动本地 OrientBD 服务器、加载图表、执行我们的进程,然后关闭。因此,我需要能够OServer从 Java 中嵌入启动过程。

有很多关于如何做到这一点的建议,包括 SA 问题,但大多数似乎已经过时(所以请不要过早地将其标记为重复)。最直接相关的似乎是this,但它不起作用 - 至少对我来说。使用以下代码,我得到后续错误:

    try {
        final OServer server = OServerMain.create();
        server.startup(server.getClass().getResourceAsStream("/orientdb-server-config.xml"));
        server.activate();
    } catch (Exception e) {
        e.printStackTrace();
        System.exit(-1);
    }

2021-12-07 21:47:39:323 INFO  Loading configuration from input stream [OServerConfigurationLoaderXml]
2021-12-07 21:47:39:633 INFO  OrientDB Server v3.2.3 (build dc98198215aa57baf29b32adb657dc3733acdb55, branch develop) is starting up... [OServer]java.lang.NullPointerException
    at com.orientechnologies.orient.core.Orient.onEmbeddedFactoryInit(Orient.java:957)
    at com.orientechnologies.orient.core.db.OrientDBEmbedded.<init>(OrientDBEmbedded.java:97)
    at com.orientechnologies.orient.core.db.OrientDBInternal.embedded(OrientDBInternal.java:119)
    at com.orientechnologies.orient.server.OServer.startupFromConfiguration(OServer.java:388)
    at com.orientechnologies.orient.server.OServer.startup(OServer.java:314)
    at ems.definitions.instance.Graph.<init>(Graph.java:47)

我正在使用 OrientDB 3.2.3 版;从这里.jar下载的“ALL” 。请注意,这个 jar 不包含参数文件,所以我直接从源GitHub下载了它。orientdb-server-config.xml

我的具体实现、我的一般方法或我正在使用的默认配置文件是否存在问题?我期待听到你的想法。

4

1 回答 1

0

这个问题有三个方面:

  1. 我使用的是网站提供的“ALL” .jar。相反,我需要使用完整源代码中提供的库。
  2. 我没有考虑到当代码失败时,它没有删除它创建一半的数据库,因此无法执行我试图修复的代码。为了避免这种情况,我必须在初始化之前实现一个临时的故障安全来删除数据库。
  3. 我总体上使用了错误的(?)策略。

我的工作方法如下。

orientDB = new OrientDB("embedded:/tmp/","admin","adminpwd", OrientDBConfig.defaultConfig());

/** THIS IS VERY MUCH ONLY FOR LOCAL TESTING **/
if(orientDB.exists(name))
    orientDB.drop(name);

if(!orientDB.exists(name)) // if the database does not already exist, create it.
    orientDB.execute("create database " + name + " PLOCAL users ( admin identified by 'adminpwd' role admin)");
db = orientDB.open(name, "admin", "adminpwd");
于 2021-12-07T20:18:31.663 回答