Сервер Neo4j с использованием Java Bolt neo4j-ogm в Weblogic

У меня проблема с подключением к серверу neo4j из Java EE.

Я использую:
- neo4j 3.0.1 в режиме сервера на локальном хосте
- Weblogic 12.1.3
- JEE 7
- neo4j-ogm-core 2.0.3
- neo4j-ogm-bolt-driver 2.0.3

Мои зависимости Maven:

<dependency>
    <groupId>org.neo4j</groupId>
    <artifactId>neo4j-ogm-core</artifactId>
    <version>2.0.3</version>
</dependency>
<dependency>
    <groupId>org.neo4j</groupId>
    <artifactId>neo4j-ogm-bolt-driver</artifactId>
    <version>2.0.3</version>
</dependency>

Мои ogm.properties в ресурсах / META-INF:

#Driver, required
driver=org.neo4j.ogm.drivers.bolt.driver.BoltDriver

#URI of the Neo4j database, required. If no port is specified, the default port 7687 is used. Otherwise, a port can be specified with bolt://neo4j:password@localhost:1234
URI=bolt://neo4j:xxxxxx@localhost

#Connection pool size (the maximum number of sessions per URL), optional, defaults to 50
connection.pool.size=150

#Encryption level (TLS), optional, defaults to REQUIRED. Valid values are NONE,REQUIRED
encryption.level=NONE

#Trust strategy, optional, not used if not specified. Valid values are TRUST_ON_FIRST_USE,TRUST_SIGNED_CERTIFICATES
trust.strategy=TRUST_ON_FIRST_USE

Я использую EJB Singleton для определения Session Factory:

@Singleton
public class Neo4jSessionFactory {

    private SessionFactory sessionFactory;

    @PostConstruct
    public void init() {
        sessionFactory = new SessionFactory("com.toto.poc.ejb.data.access");
    }

    /**
     * Get neo4j session
     * @return the session
     */
    public Session getNeo4jSession() {
        return sessionFactory.openSession();
    }
}

он находится в пакете com.toto.poc.ejb.data.access.

У меня есть EJB для определения бизнес-метода, который нужно вызвать:

@Stateless
public class TopologyBusiness {

    private @EJB Neo4jSessionFactory neo4jSessionFactory;

    public Iterable<Map<String, Object>> getApplication(String irt) {
        String query = "MATCH (a:Application) WHERE a.irt = '" + irt + "' RETURN a";

        Session session = neo4jSessionFactory.getNeo4jSession();

        return session.query(query, Collections.emptyMap());
    }
}

Но когда мой клиент вызывает TopologyBusiness, вызывается метод init (PostConstruct) Neo4jSessionFactory, и возникает ошибка:

com.oracle.pitchfork.interfaces.LifecycleCallbackException: Failure to invoke public void com.toto.poc.ejb.data.access.Neo4jSessionFactory.init() on bean class class com.toto.poc.ejb.data.access.Neo4jSessionFactory_wi88u8_Impl with args: null
    at com.oracle.pitchfork.inject.Jsr250Metadata.invokeLifecycleMethod(Jsr250Metadata.java:379)
    at com.oracle.pitchfork.inject.Jsr250Metadata.invokeLifecycleMethods(Jsr250Metadata.java:352)
    at com.oracle.pitchfork.intercept.InterceptionMetadata.invokeLifecycleMethods(InterceptionMetadata.java:399)
    at weblogic.ejb.container.injection.EjbComponentCreatorImpl.invokePostConstruct(EjbComponentCreatorImpl.java:55)
    at weblogic.ejb.container.manager.SingletonSessionManager.constructAndInitBean(SingletonSessionManager.java:330)
    Truncated. see log file for complete stacktrace
Caused By: java.lang.reflect.InvocationTargetException
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.lang.reflect.Method.invoke(Method.java:498)
    at com.oracle.pitchfork.inject.Jsr250Metadata.invokeLifecycleMethod(Jsr250Metadata.java:377)
    Truncated. see log file for complete stacktrace
Caused By: java.lang.RuntimeException: org.neo4j.ogm.exception.ServiceNotFoundException: Resource: zip:C:/oracle/wls/12.1.3/user_projects/domains/CMDB/servers/LocalServer/tmp/_WL_user/poc-cdb-ear_ear/a8qjfi/poc-cdb-ejb-1.0-SNAPSHOT.jar!/com/toto.poc/ejb/data/access
    at org.neo4j.ogm.ClassUtils.getUniqueClasspathElements(ClassUtils.java:178)
    at org.neo4j.ogm.scanner.ClassPathScanner.getUniqueClasspathElements(ClassPathScanner.java:158)
    at org.neo4j.ogm.scanner.ClassPathScanner.scan(ClassPathScanner.java:130)
    at org.neo4j.ogm.metadata.DomainInfo.load(DomainInfo.java:316)
    at org.neo4j.ogm.metadata.DomainInfo.<init>(DomainInfo.java:67)
    Truncated. see log file for complete stacktrace
Caused By: org.neo4j.ogm.exception.ServiceNotFoundException: Resource: zip:C:/oracle/wls/12.1.3/user_projects/domains/CMDB/servers/LocalServer/tmp/_WL_user/poc-cdb-ear_ear/a8qjfi/poc-cdb-ejb-1.0-SNAPSHOT.jar!/com/toto.poc/ejb/data/access
    at org.neo4j.ogm.service.ResourceService.resolve(ResourceService.java:53)
    at org.neo4j.ogm.ClassUtils.getUniqueClasspathElements(ClassUtils.java:175)
    at org.neo4j.ogm.scanner.ClassPathScanner.getUniqueClasspathElements(ClassPathScanner.java:158)
    at org.neo4j.ogm.scanner.ClassPathScanner.scan(ClassPathScanner.java:130)
    at org.neo4j.ogm.metadata.DomainInfo.load(DomainInfo.java:316)
    Truncated. see log file for complete stacktrace

Основная причина, по-видимому, в следующем:

Caused By: org.neo4j.ogm.exception.ServiceNotFoundException: Resource: zip:C:/oracle/wls/12.1.3/user_projects/domains/CMDB/servers/LocalServer/tmp/_WL_user/poc-cdb-ear_ear/a8qjfi/poc-cdb-ejb-1.0-SNAPSHOT.jar!/com/toto.poc/ejb/data/access

Понятия не имею, зачем ему искать zip в пути к классам ...
Спасибо за вашу помощь!


person ju113n    schedule 07.06.2016    source источник


Ответы (1)


Я наконец могу решить свою проблему. Я просмотрел странные форумы и нашел кого-то, у кого была аналогичная проблема на JBoss.
Так мне удалось перенести это решение на Weblogic.

Во-первых, вам нужно создать свой собственный преобразователь ресурсов, чтобы обеспечить способ работы с «zip».
Перезаписать ResourceResolver и реализовать метод разрешения, как показано ниже:

public class Neo4jResourceResolver implements ResourceResolver {

    @Override
    public File resolve(URL resource) throws Exception {

        switch (resource.getProtocol()) {
            case "file":
                return new File(resource.toURI());
            case "jar":
            case "zip":
                String jarPath = resource.getPath().substring(0, resource.getPath().indexOf("!"));
                return new File(jarPath);
            default:
                return null;
        }
    }
}

Затем создайте файл с именем «org.neo4j.ogm.classloader.ResourceResolver» по пути «src / main / resources / META-INF / services».
Это файл содержит только одну строку, путь к вашему пользовательскому классу ResourceResolver:

com.toto.poc.core.access.ucmdb.Neo4jResourceResolver

И это волшебство, работает !!!

Neo4j теперь исследует jar-архив, найдет ваши NodeEntities и сопоставит их с вашим графиком :)

person ju113n    schedule 13.06.2016