java - 将 SDN-4 添加到 GF-3 : Exception while loading the app: IllegalStateException: ContainerBase. addChild : start: org. apache.catalina.LifecycleException

标签 java cdi glassfish-3 spring-data-neo4j spring-data-neo4j-4

为了使用 neo4j-graphdatabase 独立服务器,我将 SDN 3.1.2 的依赖项添加到我的 pom 中。

 <dependency>
        <groupId>org.springframework.data</groupId>
        <artifactId>spring-data-neo4j-rest</artifactId>
        <version>3.1.2.RELEASE</version>
 </dependency>

由于 Neo4jCdiRepositoryExtension,我可以使用 spring-data-neo4j,而无需完整的 Spring 框架(通过 CDI)。

现在我想将我的SDN版本更新到4.0.0.M1。

<dependency>
    <groupId>org.springframework.data</groupId>
    <artifactId>spring-data-neo4j</artifactId>
    <version>4.0.0.M1</version>
</dependency>

我必须创建自己的 Neo4jCdiRepositoryExtension,这看起来非常简单。部署过程构建我的新扩展。 要使用我的扩展,我需要此类提供所有所需的配置:

@ApplicationScoped
public class Neo4jConfigurationProvider {

@Resource(lookup = "rest/neo4j")
private String baseUriString;
private static final String PERSISTENCE_ROOT = "...";
private SessionFactory sessionFactory;
private Neo4jServer neo4jServer;
private Session session;

@PostConstruct
public void init() {
    neo4jServer = new RemoteServer(baseUriString);
    sessionFactory = new SessionFactory(PERSISTENCE_ROOT + ".person", PERSISTENCE_ROOT + ".relation",
            PERSISTENCE_ROOT + ".relations_type");
    session = sessionFactory.openSession(baseUriString);
}

@Produces
public SessionFactory sessionFactory() {
    return sessionFactory;
}

@Produces
public Neo4jServer neo4jServer() {
    return neo4jServer;
}

@Produces
public Neo4jTemplate neo4jTemplate() {
    return new Neo4jTemplate(session);
}
}

如果我想部署它,我的 glassfish 3 服务器会给出此错误消息:

remote failure: Error occurred during deployment: Exception while loading the app :
java.lang.IllegalStateException: ContainerBase.addChild: start: 
org.apache.catalina.LifecycleException: 
org.apache.catalina.LifecycleException: 
com.sun.jersey.spi.inject.Errors$ErrorMessagesException. 
Please see server.log for more details.

我现在的问题是:如何修复此错误?

最佳答案

首先我找不到任何server.log,因为我的服务器没有启动。所以我复制了一个有效的版本,添加 sdn-4 依赖项并尝试获取它的任何日志。这是我的 server.log 中的错误:

The following errors and warnings have been detected with resource and/or provider classes: familymanager_1 | SEVERE: Missing dependency for constructor public org.neo4j.server.LoggingProvider(org.neo4j.kernel.logging.Logging) at parameter index 0 familymanager_1 | SEVERE: Missing dependency for constructor public org.neo4j.server.rest.transactional.TransactionFilter(org.neo4j.server.database.Database) at parameter index 0 familymanager_1 | SEVERE: Missing dependency for constructor public org.neo4j.server.rest.repr.InputFormatProvider(org.neo4j.server.rest.repr.RepresentationFormatRepository) at parameter index 0 familymanager_1 | SEVERE: Missing dependency for constructor public org.neo4j.server.rest.repr.OutputFormatProvider(org.neo4j.server.rest.repr.RepresentationFormatRepository) at parameter index 0 familymanager_1 | SEVERE: Missing dependency for constructor public org.neo4j.server.rest.paging.LeaseManagerProvider(org.neo4j.server.rest.paging.LeaseManager) at parameter index 0 familymanager_1 | SEVERE: Missing dependency for constructor public org.neo4j.server.NeoServerProvider(org.neo4j.server.NeoServer) at parameter index 0 familymanager_1 | SEVERE: Missing dependency for constructor public org.neo4j.server.plugins.PluginInvocatorProvider(org.neo4j.server.AbstractNeoServer) at parameter index 0 familymanager_1 | SEVERE: Missing dependency for constructor public org.neo4j.server.database.ExecutionEngineProvider(org.neo4j.server.database.CypherExecutor) at parameter index 0 familymanager_1 | SEVERE: Missing dependency for constructor public org.neo4j.server.database.CypherExecutorProvider(org.neo4j.server.database.CypherExecutor) at parameter index 0 familymanager_1 | SEVERE: Missing dependency for constructor public org.neo4j.server.database.GraphDatabaseServiceProvider(org.neo4j.server.database.Database) at parameter index 0 familymanager_1 | SEVERE: Missing dependency for constructor public org.neo4j.server.database.DatabaseProvider(org.neo4j.server.database.Database) at parameter index 0 familymanager_1 | SEVERE: Missing dependency for constructor public org.neo4j.server.rrd.RrdDbProvider(org.neo4j.server.database.RrdDbWrapper) at parameter index 0 familymanager_1 | SEVERE: Missing dependency for constructor public org.neo4j.server.web.WebServerProvider(org.neo4j.server.web.WebServer) at parameter index 0 familymanager_1 | SEVERE: Missing dependency for constructor public org.neo4j.server.web.InjectableWrapper(org.neo4j.server.plugins.Injectable) at parameter index 0 familymanager_1 | SEVERE: Missing dependency for constructor public org.neo4j.server.rest.dbms.UserService(org.neo4j.server.security.auth.AuthManager,org.neo4j.server.rest.repr.InputFormat,org.neo4j.server.rest.repr.OutputFormat) at parameter index 0 familymanager_1 | SEVERE: Missing dependency for constructor public org.neo4j.server.rest.management.console.ConsoleService(org.neo4j.kernel.configuration.Config,org.neo4j.server.database.Database,javax.servlet.http.HttpServletRequest,org.neo4j.server.rest.repr.OutputFormat,org.neo4j.server.database.CypherExecutor) at parameter index 0 familymanager_1 | SEVERE: Missing dependency for constructor public org.neo4j.server.rest.discovery.DiscoveryService(org.neo4j.kernel.configuration.Config,org.neo4j.server.rest.repr.OutputFormat) at parameter index 0

我在 spring-data-neo4j 依赖项中搜索其他服务器实例,并找到了“neo4j-server”。 我将此服务器从我的 pom 中的 sdn-4 依赖项中排除,以使用此框架:

    <dependency>
        <groupId>org.springframework.data</groupId>
        <artifactId>spring-data-neo4j</artifactId>
        <version>4.0.0.RC1</version>
        <exclusions>
            <exclusion>
                <groupId>org.neo4j.app</groupId>
                <artifactId>neo4j-server</artifactId>
            </exclusion>
        </exclusions>
    </dependency>

现在我可以在JavaEE 6下使用spring-data-neo4j 4-RC1版本了。

关于java - 将 SDN-4 添加到 GF-3 : Exception while loading the app: IllegalStateException: ContainerBase. addChild : start: org. apache.catalina.LifecycleException,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31450988/

相关文章:

java - 计算素数(新手)

events - @在 session 范围 bean 中观察?

jakarta-ee - DAO 和服务类应该使用哪个 CDI 范围

cdi - 动态 CDI 注入(inject)@Named

java - 除非重新启动 Glassfish 服务器,否则不会反射(reflect)属性文件更改

java - hibernate 映射: creating FK relation in existing db for join operations

java - 无法编译 Guava 23 的 SimpleTimeLimiter 示例

java - 在webapp文件夹中动态添加.xhtml文件

java - 矩阵乘法顺序与并行性能测试

deployment - WAR 不会从自动部署中重新部署到 Glassfish 中