【问题标题】:How to integrate neo4j-ogm with unmanaged extension?如何将 neo4j-ogm 与非托管扩展集成?
【发布时间】:2018-11-29 11:12:46
【问题描述】:

我正在尝试查找一些示例或演示“如何将 OGM 与非托管扩展集成”,但找不到任何好的示例。

我尝试将 restapi 用作非托管扩展,并且单独使用它可以正常工作,但 OGM 具有智能对象映射功能,可以通过 SessionSession 来实现 SessionFactory.

     private final static SessionFactory sessionFactory = new SessionFactory("some.domain");
     sessionFactory .openSession();

现在如何使用 OGM 与非托管扩展集成?

有人可以帮我做同样的事情吗?

编辑 1

请查看以下屏幕截图

编辑 2

下面是我们写的代码

import org.neo4j.ogm.drivers.embedded.extension.OgmPluginInitializer;

public class MyApplicationPluginInitializer extends OgmPluginInitializer {


       public MyApplicationPluginInitializer(String packages) {   

              super(packages);

       }


}

类 TopologyExtController

@Path("/")
public class TopologyExtController {


       @javax.ws.rs.core.Context 
       public org.neo4j.ogm.session.Session session;

       public TopologyExtController( ) {

       }

       @POST
       @Path("/uiv/topology")
       public Response getTopology(TopologyDescription topology, @javax.ws.rs.core.Context HttpHeaders headers) {
              try{                

                     ObjectMapper mapper = new ObjectMapper();
                     Map convertValue = mapper.convertValue(topology, Map.class);

                     Map<String, Object> map = new HashMap<>();           
                     map.put("topology", convertValue);

                     //OGM session used execute the procedure and return the mapped result to end user.
                     Result query = session.query("call uiv.traversal($topology)",map);             

                     Iterator<Map<String, Object>> iterator = query.iterator();
                     if (iterator.hasNext()) {
                           Map<String, Object> next = iterator.next();
                           Object object = next.get("rootNodes");

                           return Response.ok(object).status(200).build();

                     }


              }catch (Exception e)
              {
                     e.printStackTrace();
              }             

              return Response.ok("Something went wrong").status(400).build();

       }


}

META-INF 条目 \META-INF\services\org.neo4j.server.plugins.PluginLifecycle

-   framework.traversal.ext.config.MyApplicationPluginInitializer

但是我们得到的错误

11 月 30 日 15:17:27 surerest2 neo4j: 2018-11-30 09:47:27.611+0000 错误 使用资源检测到以下错误和警告 和/或提供者类:11 月 30 日 15:17:27 surerest2 neo4j:严重: 缺少字段依赖项:public org.neo4j.ogm.session.Session framework.traversal.ext.ogm.controller.TopologyExtController.session 11 月 30 日 15:17:27 surerest2 neo4j: 2018-11-30 09:47:27.612+0000 警告 11 月 30 日 15:17:27 不可用 com.sun.jersey.spi.inject.Errors$ErrorMessagesException 11 月 30 日 15:17:27 surerest2 neo4j:在 com.sun.jersey.spi.inject.Errors.processErrorMessages(Errors.java:170) 11 月 30 日 15:17:27surerest2 neo4j:在 com.sun.jersey.spi.inject.Errors.postProcess(Errors.java:136)11 月 30 日 15:17:27 surerest2 neo4j:在 com.sun.jersey.spi.inject.Errors.processWithErrors(Errors.java:199) 11 月 30 日 15:17:27surerest2 neo4j:在 com.sun.jersey.server.impl.application.WebApplicationImpl.initiate(WebApplicationImpl.java:795) 11 月 30 日 15:17:27surerest2 neo4j:在 com.sun.jersey.server.impl.application.WebApplicationImpl.initiate(WebApplicationImpl.java:790) 11 月 30 日 15:17:27surerest2 neo4j:在 com.sun.jersey.spi.container.servlet.ServletContainer.initiate(ServletContainer.java:509) 11 月 30 日 15:17:27surerest2 neo4j:在 com.sun.jersey.spi.container.servlet.ServletContainer$InternalWebComponent.initiate(ServletContainer.java:339) 11 月 30 日 15:17:27surerest2 neo4j:在 com.sun.jersey.spi.container.servlet.WebComponent.load(WebComponent.java:605) 11 月 30 日 15:17:27surerest2 neo4j:在 com.sun.jersey.spi.container.servlet.WebComponent.init(WebComponent.java:207) 11 月 30 日 15:17:27surerest2 neo4j:在 com.sun.jersey.spi.container.servlet.ServletContainer.init(ServletContainer.java:394) 11 月 30 日 15:17:27surerest2 neo4j:在 com.sun.jersey.spi.container.servlet.ServletContainer.init(ServletContainer.java:577) 11 月 30 日 15:17:27surerest2 neo4j:在 javax.servlet.GenericServlet.init(GenericServlet.java:244) 11 月 30 日 15:17:27 surerest2 neo4j:在 org.eclipse.jetty.servlet.ServletHolder.initServlet(ServletHolder.java:665) 11 月 30 日 15:17:27surerest2 neo4j:在 org.eclipse.jetty.servlet.ServletHolder.initialize(ServletHolder.java:423) 11 月 30 日 15:17:27surerest2 neo4j:在 org.eclipse.jetty.servlet.ServletHandler.initialize(ServletHandler.java:760) 11 月 30 日 15:17:27surerest2 neo4j:在 org.eclipse.jetty.servlet.ServletContextHandler.startContext(ServletContextHandler.java:348) 11 月 30 日 15:17:27surerest2 neo4j:在 org.eclipse.jetty.server.handler.ContextHandler.doStart(ContextHandler.java:785) 11 月 30 日 15:17:27surerest2 neo4j:在 org.eclipse.jetty.servlet.ServletContextHandler.doStart(ServletContextHandler.java:261) 11 月 30 日 15:17:27surerest2 neo4j:在 org.eclipse.jetty.util.component.AbstractLifeCycle.start(AbstractLifeCycle.java:68) 11 月 30 日 15:17:27surerest2 neo4j:在 org.eclipse.jetty.util.component.ContainerLifeCycle.start(ContainerLifeCycle.java:133) 11 月 30 日 15:17:27surerest2 neo4j:在 org.eclipse.jetty.util.component.ContainerLifeCycle.doStart(ContainerLifeCycle.java:115) 11 月 30 日 15:17:27surerest2 neo4j:在 org.eclipse.jetty.server.handler.AbstractHandler.doStart(AbstractHandler.java:113) 11 月 30 日 15:17:27surerest2 neo4j:在 org.eclipse.jetty.util.component.AbstractLifeCycle.start(AbstractLifeCycle.java:68) 11 月 30 日 15:17:27surerest2 neo4j:在 org.eclipse.jetty.util.component.ContainerLifeCycle.start(ContainerLifeCycle.java:133) 11 月 30 日 15:17:27surerest2 neo4j:在 org.eclipse.jetty.server.Server.start(Server.java:418) 11 月 30 日 15:17:27 surerest2 neo4j:在 org.eclipse.jetty.util.component.ContainerLifeCycle.doStart(ContainerLifeCycle.java:107) 11 月 30 日 15:17:27surerest2 neo4j:在 org.eclipse.jetty.server.handler.AbstractHandler.doStart(AbstractHandler.java:113) 11 月 30 日 15:17:27surerest2 neo4j:在 org.eclipse.jetty.server.Server.doStart(Server.java:385) 11 月 30 日 15:17:27 surerest2 neo4j:在 org.eclipse.jetty.util.component.AbstractLifeCycle.start(AbstractLifeCycle.java:68) 11 月 30 日 15:17:27surerest2 neo4j:在 org.neo4j.server.web.Jetty9WebServer.startJetty(Jetty9WebServer.java:320) 11 月 30 日 15:17:27surerest2 neo4j:在 org.neo4j.server.web.Jetty9WebServer.start(Jetty9WebServer.java:152) 11 月 30 日 15:17:27surerest2 neo4j:在 org.neo4j.server.AbstractNeoServer.startWebServer(AbstractNeoServer.java:321) 11 月 30 日 15:17:27surerest2 neo4j:在 org.neo4j.server.AbstractNeoServer.access$700(AbstractNeoServer.java:102) 11 月 30 日 15:17:27surerest2 neo4j:在 org.neo4j.server.AbstractNeoServer$ServerComponentsLifecycleAdapter.start(AbstractNeoServer.java:527) 11 月 30 日 15:17:27surerest2 neo4j:在 org.neo4j.kernel.lifecycle.LifeSupport$LifecycleInstance.start(LifeSupport.java:445) 11 月 30 日 15:17:27surerest2 neo4j:在 org.neo4j.kernel.lifecycle.LifeSupport.start(LifeSupport.java:107) 十一月 30 15:17:27surerest2 neo4j:在 org.neo4j.server.AbstractNeoServer.start(AbstractNeoServer.java:212) 11 月 30 日 15:17:27surerest2 neo4j:在 org.neo4j.server.ServerBootstrapper.start(ServerBootstrapper.java:111) 11 月 30 日 15:17:27surerest2 neo4j:在 org.neo4j.server.ServerBootstrapper.start(ServerBootstrapper.java:79) 11 月 30 日 15:17:27surerest2 neo4j:在 com.neo4j.server.enterprise.CommercialEntryPoint.main(CommercialEntryPoint.java:22) 11 月 30 日 15:17:27 surerest2 neo4j: 2018-11-30 09:47:27.639+0000 错误 在 127.0.0.1:7474 上启动 Neo4j 失败: org.neo4j.server.web.NeoServletContainer-737fd68@2dde7c07==org.neo4j.server.web.NeoServletContainer,jsp=null,order=-1,inst=false Nov 30 15:17:27 surerest2 neo4j: 2018-11 -30 09:47:27.658+0000 信息 停止... 11 月 30 日 15:17:28 surerest2 neo4j: 2018-11-30 09:47:28.279+0000 信息已停止。 11 月 30 日 15:17:28 2018-11-30 09:47:28.281+0000 错误无法启动 Neo4j:正在启动 Neo4j 失败:组件 'org.neo4j.server.AbstractNeoServer$ServerComponentsLifecycleAdapter@6c49db66' 已成功初始化,但无法启动。请参阅 附加原因异常“空”。启动 Neo4j 失败:组件 'org.neo4j.server.AbstractNeoServer$ServerComponentsLifecycleAdapter@6c49db66' 已成功初始化,但无法启动。请参阅 附加原因异常“空”。 11 月 30 日 15:17:28 org.neo4j.server.ServerStartupException:启动 Neo4j 失败: 零件 'org.neo4j.server.AbstractNeoServer$ServerComponentsLifecycleAdapter@6c49db66' 已成功初始化,但无法启动。请参阅 附加原因异常“空”。 11 月 30 日 15:17:28surerest2 neo4j:在 org.neo4j.server.exception.ServerStartupErrors.translateToServerStartupError(ServerStartupErrors.java:68) 11 月 30 日 15:17:28surerest2 neo4j:在 org.neo4j.server.AbstractNeoServer.start(AbstractNeoServer.java:220) 11 月 30 日 15:17:28surerest2 neo4j:在 org.neo4j.server.ServerBootstrapper.start(ServerBootstrapper.java:111) 11 月 30 日 15:17:28surerest2 neo4j:在 org.neo4j.server.ServerBootstrapper.start(ServerBootstrapper.java:79) 11 月 30 日 15:17:28surerest2 neo4j:在 com.neo4j.server.enterprise.CommercialEntryPoint.main(CommercialEntryPoint.java:22) 11 月 30 日 15:17:28 surerest2 neo4j: 原因: org.neo4j.kernel.lifecycle.LifecycleException:组件 'org.neo4j.server.AbstractNeoServer$ServerComponentsLifecycleAdapter@6c49db66' 已成功初始化,但无法启动。请参阅 附加原因异常“空”。 11 月 30 日 15:17:28surerest2 neo4j:在 org.neo4j.kernel.lifecycle.LifeSupport$LifecycleInstance.start(LifeSupport.java:466) 11 月 30 日 15:17:28surerest2 neo4j:在 org.neo4j.kernel.lifecycle.LifeSupport.start(LifeSupport.java:107) 十一月 30 15:17:28surerest2 neo4j:在 org.neo4j.server.AbstractNeoServer.start(AbstractNeoServer.java:212) 11 月 30 日 15:17:28surerest2 neo4j:... 3 更多 11 月 30 日 15:17:28surerest2 neo4j:引起:javax.servlet.ServletException: org.neo4j.server.web.NeoServletContainer-737fd68@2dde7c07==org.neo4j.server.web.NeoServletContainer,jsp=null,order=-1,inst=false 11 月 30 日 15:17:28 surerest2 neo4j: at org.eclipse.jetty.servlet.ServletHolder.initServlet(ServletHolder.java:686) 11 月 30 日 15:17:28surerest2 neo4j:在 org.eclipse.jetty.servlet.ServletHolder.initialize(ServletHolder.java:423) 11 月 30 日 15:17:28surerest2 neo4j:在 org.eclipse.jetty.servlet.ServletHandler.initialize(ServletHandler.java:760) 11 月 30 日 15:17:28surerest2 neo4j:在 org.eclipse.jetty.servlet.ServletContextHandler.startContext(ServletContextHandler.java:348) 11 月 30 日 15:17:28surerest2 neo4j:在 org.eclipse.jetty.server.handler.ContextHandler.doStart(ContextHandler.java:785) 11 月 30 日 15:17:28surerest2 neo4j:在 org.eclipse.jetty.servlet.ServletContextHandler.doStart(ServletContextHandler.java:261) 11 月 30 日 15:17:28surerest2 neo4j:在 org.eclipse.jetty.util.component.AbstractLifeCycle.start(AbstractLifeCycle.java:68) 11 月 30 日 15:17:28surerest2 neo4j:在 org.eclipse.jetty.util.component.ContainerLifeCycle.start(ContainerLifeCycle.java:133) 11 月 30 日 15:17:28surerest2 neo4j:在 org.eclipse.jetty.util.component.ContainerLifeCycle.doStart(ContainerLifeCycle.java:115) 11 月 30 日 15:17:28surerest2 neo4j:在 org.eclipse.jetty.server.handler.AbstractHandler.doStart(AbstractHandler.java:113) 11 月 30 日 15:17:28surerest2 neo4j:在 org.eclipse.jetty.util.component.AbstractLifeCycle.start(AbstractLifeCycle.java:68) 11 月 30 日 15:17:28surerest2 neo4j:在 org.eclipse.jetty.util.component.ContainerLifeCycle.start(ContainerLifeCycle.java:133) 11 月 30 日 15:17:28surerest2 neo4j:在 org.eclipse.jetty.server.Server.start(Server.java:418) 11 月 30 日 15:17:28 surerest2 neo4j:在 org.eclipse.jetty.util.component.ContainerLifeCycle.doStart(ContainerLifeCycle.java:107) 11 月 30 日 15:17:28surerest2 neo4j:在 org.eclipse.jetty.server.handler.AbstractHandler.doStart(AbstractHandler.java:113) 11 月 30 日 15:17:28surerest2 neo4j:在 org.eclipse.jetty.server.Server.doStart(Server.java:385) 11 月 30 日 15:17:28 surerest2 neo4j:在 org.eclipse.jetty.util.component.AbstractLifeCycle.start(AbstractLifeCycle.java:68) 11 月 30 日 15:17:28surerest2 neo4j:在 org.neo4j.server.web.Jetty9WebServer.startJetty(Jetty9WebServer.java:320) 11 月 30 日 15:17:28surerest2 neo4j:在 org.neo4j.server.web.Jetty9WebServer.start(Jetty9WebServer.java:152) 11 月 30 日 15:17:28surerest2 neo4j:在 org.neo4j.server.AbstractNeoServer.startWebServer(AbstractNeoServer.java:321) 11 月 30 日 15:17:28surerest2 neo4j:在 org.neo4j.server.AbstractNeoServer.access$700(AbstractNeoServer.java:102) 11 月 30 日 15:17:28surerest2 neo4j:在 org.neo4j.server.AbstractNeoServer$ServerComponentsLifecycleAdapter.start(AbstractNeoServer.java:527) 11 月 30 日 15:17:28surerest2 neo4j:在 org.neo4j.kernel.lifecycle.LifeSupport$LifecycleInstance.start(LifeSupport.java:445) 11 月 30 日 15:17:28surerest2 neo4j: ... 5 更多 11 月 30 日 15:17:28surerest2 neo4j:由以下原因引起: com.sun.jersey.spi.inject.Errors$ErrorMessagesException 11 月 30 日 15:17:28 surerest2 neo4j:在 com.sun.jersey.spi.inject.Errors.processErrorMessages(Errors.java:170) 11 月 30 日 15:17:28surerest2 neo4j:在 com.sun.jersey.spi.inject.Errors.postProcess(Errors.java:136)11 月 30 日 15:17:28 surerest2 neo4j:在 com.sun.jersey.spi.inject.Errors.processWithErrors(Errors.java:199) 11 月 30 日 15:17:28surerest2 neo4j:在 com.sun.jersey.server.impl.application.WebApplicationImpl.initiate(WebApplicationImpl.java:795) 11 月 30 日 15:17:28surerest2 neo4j:在 com.sun.jersey.server.impl.application.WebApplicationImpl.initiate(WebApplicationImpl.java:790) 11 月 30 日 15:17:28surerest2 neo4j:在 com.sun.jersey.spi.container.servlet.ServletContainer.initiate(ServletContainer.java:509) 11 月 30 日 15:17:28surerest2 neo4j:在 com.sun.jersey.spi.container.servlet.ServletContainer$InternalWebComponent.initiate(ServletContainer.java:339) 11 月 30 日 15:17:28surerest2 neo4j:在 com.sun.jersey.spi.container.servlet.WebComponent.load(WebComponent.java:605) 11 月 30 日 15:17:28surerest2 neo4j:在 com.sun.jersey.spi.container.servlet.WebComponent.init(WebComponent.java:207) 11 月 30 日 15:17:28surerest2 neo4j:在 com.sun.jersey.spi.container.servlet.ServletContainer.init(ServletContainer.java:394) 11 月 30 日 15:17:28surerest2 neo4j:在 com.sun.jersey.spi.container.servlet.ServletContainer.init(ServletContainer.java:577) 11 月 30 日 15:17:28surerest2 neo4j:在 javax.servlet.GenericServlet.init(GenericServlet.java:244) 11 月 30 日 15:17:28 surerest2 neo4j:在 org.eclipse.jetty.servlet.ServletHolder.initServlet(ServletHolder.java:665) 11 月 30 日 15:17:28 surerest2 neo4j: ... 27 更多

【问题讨论】:

    标签: neo4j spring-data-neo4j neo4j-ogm


    【解决方案1】:

    这通常是不可能的。 Neo4j-OGM 使用 Cypher 抽象了所有传输模式(Bolt、HTTP、嵌入式)。

    ...但是如果您的非托管扩展与您的业务逻辑完全分离(例如,没有还包含 Neo4j-OGM 调用的事务边界),您可以直接通过 (Neo4j-OGM) HTTP 驱动程序创建调用:

    HttpDriver httpDriver = (HttpDriver) sessionFactory.getDriver();
    CloseableHttpResponse response = httpDriver.executeHttpRequest(new HttpGet("http://somewhere"));
    response.getEntity().getContent()....
    

    请注意,这只是使用原始连接的一种技巧。

    编辑(添加运行inside Neo4j的信息):

    in the documentation 所述,您需要提供自己的OgmPluginInitializer,就像您已经提供的那样。但是您的实现/构造函数确实希望在某处提供该包。加载扩展的服务扩展不知道您的包结构,因此初始化程序类应该看起来......喜欢

    public class MyApplicationPluginInitializer extends OgmPluginInitializer {
       public MyApplicationPluginInitializer() {   
              super("Your package to scan");
       }
    }
    

    作为警告:用于提供此功能的 API 在 Neo4j 3.5 中已弃用。并且可以在即将发布的版本中删除。因此,此功能可能还会根据更改进行重构或删除。

    【讨论】:

    • 感谢您的回复,我需要在我的非托管扩展中进行 OGM 会话,这可能吗?
    • 在服务器端的非托管扩展中使用它不是一个好主意。如果您在扩展中获得所有依赖项,理论上可能可以将 GraphDatabaseService 传递给 EmbeddedDriver 实例,但是您将失去直接访问数据库的所有好处,最重要的是,您还必须将整个域作为一个库到扩展中。
    • 请看一下这个[链接](neo4j.com/docs/ogm-manual/current/referenceneo4j.com/docs/ogm-manual/current/reference/…)。我们正在尝试这种方法,但我们无法使其发挥作用?
    • 问题不在于您没有通过MyApplicationPluginInitializer 中的实际包这一事实吗?请再次查看文档,它说您必须在构造函数中设置自己的包。服务扩展不知道如何实例化你的插件初始化器。
    • 查看此文档neo4j.com/docs/java-reference/current/extending-neo4j/… 并检查 Neo4j 类 Neo4j-OGM 依赖,它在 3.5 中已弃用,必须在扩展的构造函数中手动创建 SessionFactory(文档中的示例) .
    猜你喜欢
    • 1970-01-01
    • 2016-10-08
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2015-11-06
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多