0

我是 Glassfish 的新手,我已经发现 Glassfish 4.1.1(我猜是 4.1)有一个错误。我在谷歌搜索后解决了这个问题,并更新到 Glassfish 4.1.2。现在,我在部署应用程序时收到以下异常和堆栈跟踪:

Severe:   Exception while deploying the app [DHWear-1.0]
Severe:   Exception during lifecycle processing
org.glassfish.deployment.common.DeploymentException: Failue while processing glassfish-resources.xml(s) in the archive  -- E:\Program Files\glassfish4\glassfish\domains\randomlogic\applications\DHWear-1.0\DHWweb-1.0_war\WEB-INF\lib\DHWbean-1.0.jarMETA-INF\glassfish-resources.xml (The system cannot find the path specified)
at org.glassfish.resources.admin.cli.ResourcesXMLParser.initProperties(ResourcesXMLParser.java:284)
at org.glassfish.resources.admin.cli.ResourcesXMLParser.<init>(ResourcesXMLParser.java:151)
at org.glassfish.resources.module.ResourcesDeployer.processArchive(ResourcesDeployer.java:274)
at org.glassfish.resources.module.ResourcesDeployer.processResources(ResourcesDeployer.java:766)
at org.glassfish.resources.module.ResourcesDeployer.event(ResourcesDeployer.java:715)
at org.glassfish.kernel.event.EventsImpl.send(EventsImpl.java:131)
at com.sun.enterprise.v3.server.ApplicationLifecycle.deploy(ApplicationLifecycle.java:419)
at com.sun.enterprise.v3.server.ApplicationLifecycle.deploy(ApplicationLifecycle.java:219)
at org.glassfish.deployment.admin.DeployCommand.execute(DeployCommand.java:491)
at com.sun.enterprise.v3.admin.CommandRunnerImpl$2$1.run(CommandRunnerImpl.java:539)
at com.sun.enterprise.v3.admin.CommandRunnerImpl$2$1.run(CommandRunnerImpl.java:535)
at java.security.AccessController.doPrivileged(Native Method)
at javax.security.auth.Subject.doAs(Subject.java:360)
at com.sun.enterprise.v3.admin.CommandRunnerImpl$2.execute(CommandRunnerImpl.java:534)
at com.sun.enterprise.v3.admin.CommandRunnerImpl$3.run(CommandRunnerImpl.java:565)
at com.sun.enterprise.v3.admin.CommandRunnerImpl$3.run(CommandRunnerImpl.java:557)
at java.security.AccessController.doPrivileged(Native Method)
at javax.security.auth.Subject.doAs(Subject.java:360)
at com.sun.enterprise.v3.admin.CommandRunnerImpl.doCommand(CommandRunnerImpl.java:556)
at com.sun.enterprise.v3.admin.CommandRunnerImpl.doCommand(CommandRunnerImpl.java:1464)
at com.sun.enterprise.v3.admin.CommandRunnerImpl.access$1300(CommandRunnerImpl.java:109)
at com.sun.enterprise.v3.admin.CommandRunnerImpl$ExecutionContext.execute(CommandRunnerImpl.java:1846)
at com.sun.enterprise.v3.admin.CommandRunnerImpl$ExecutionContext.execute(CommandRunnerImpl.java:1722)
at com.sun.enterprise.v3.admin.AdminAdapter.doCommand(AdminAdapter.java:534)
at com.sun.enterprise.v3.admin.AdminAdapter.onMissingResource(AdminAdapter.java:224)
at org.glassfish.grizzly.http.server.StaticHttpHandlerBase.service(StaticHttpHandlerBase.java:189)
at com.sun.enterprise.v3.services.impl.ContainerMapper$HttpHandlerCallable.call(ContainerMapper.java:459)
at com.sun.enterprise.v3.services.impl.ContainerMapper.service(ContainerMapper.java:167)
at org.glassfish.grizzly.http.server.HttpHandler.runService(HttpHandler.java:206)
at org.glassfish.grizzly.http.server.HttpHandler.doHandle(HttpHandler.java:180)
at org.glassfish.grizzly.http.server.HttpServerFilter.handleRead(HttpServerFilter.java:235)
at org.glassfish.grizzly.filterchain.ExecutorResolver$9.execute(ExecutorResolver.java:119)
at org.glassfish.grizzly.filterchain.DefaultFilterChain.executeFilter(DefaultFilterChain.java:283)
at org.glassfish.grizzly.filterchain.DefaultFilterChain.executeChainPart(DefaultFilterChain.java:200)
at org.glassfish.grizzly.filterchain.DefaultFilterChain.execute(DefaultFilterChain.java:132)
at org.glassfish.grizzly.filterchain.DefaultFilterChain.process(DefaultFilterChain.java:111)
at org.glassfish.grizzly.ProcessorExecutor.execute(ProcessorExecutor.java:77)
at org.glassfish.grizzly.nio.transport.TCPNIOTransport.fireIOEvent(TCPNIOTransport.java:536)
at org.glassfish.grizzly.strategies.AbstractIOStrategy.fireIOEvent(AbstractIOStrategy.java:112)
at org.glassfish.grizzly.strategies.WorkerThreadIOStrategy.run0(WorkerThreadIOStrategy.java:117)
at org.glassfish.grizzly.strategies.WorkerThreadIOStrategy.access$100(WorkerThreadIOStrategy.java:56)
at org.glassfish.grizzly.strategies.WorkerThreadIOStrategy$WorkerThreadRunnable.run(WorkerThreadIOStrategy.java:137)
at org.glassfish.grizzly.threadpool.AbstractThreadPool$Worker.doWork(AbstractThreadPool.java:591)
at org.glassfish.grizzly.threadpool.AbstractThreadPool$Worker.run(AbstractThreadPool.java:571)
at java.lang.Thread.run(Thread.java:748)

Severe:   Exception while deploying the app [DHWear-1.0] : Failue while processing glassfish-resources.xml(s) in the archive  -- E:\Program Files\glassfish4\glassfish\domains\randomlogic\applications\DHWear-1.0\DHWweb-1.0_war\WEB-INF\lib\DHWbean-1.0.jarMETA-INF\glassfish-resources.xml (The system cannot find the path specified)

无论我是使用 NetBeans 8.2 部署还是使用 Glassfish Web 管理控制台,都会出现此异常。

这个错误对我和它显示的路径毫无意义:

E:\Program Files\glassfish4\glassfish\domains\randomlogic\applications\DHWear-1.0\DHWweb-1.0_war\WEB-INF\lib\DHWbean-1.0.jarMETA-INF\glassfish-resources.xml

我觉得很奇怪。这部分:

\DHWbean-1.0.jarMETA-INF\

似乎有些东西被错误地解析了。在我看来应该是:

\DHWbean-1.0.jar\META-INF\

查看存档,我看到路径

\DHWear-1.0\DHWweb-1.0_war\WEB-INF\lib\DHWbean-1.0.jar\META-INF\glassfish-resources.xml

确实存在。

无论如何,有没有人遇到过这个问题,如果有,我该如何解决?

更新

我发现部署 WAR 文件并没有显示此错误,并显示 NetBeans 根本没有配置 Glassfish JDBC 资源(显然是一个开放的错误 - 有趣的是它可以与 Tomcat 服务器一起使用)。我手动将资源添加到服务器以解决该问题,但 EAR 仍然无法工作。

glassfish-resources.xml从我的三个持久单元模块中删除了这些文件,并将内容合并到一个glassfish-resources.xml具有应用程序范围的文件中。这解决了 EAR 的问题,但是现在当我部署 EAR 或 WAR 时,我得到:

Severe:   Exception while preparing the app
java.lang.NullPointerException
at org.eclipse.persistence.internal.jpa.EntityManagerSetupImpl.preInitializeCanonicalMetamodel(EntityManagerSetupImpl.java:3777)
at org.eclipse.persistence.jpa.PersistenceProvider.createContainerEntityManagerFactoryImpl(PersistenceProvider.java:381)
at org.eclipse.persistence.jpa.PersistenceProvider.createContainerEntityManagerFactory(PersistenceProvider.java:313)

我不知道为什么。

4

1 回答 1

0

事实证明,答案是由于各种原因,Glassfish 可能无法正确连接到数据源。原因可能会因数据库服务器的网络连接丢失、身份验证失败等而有所不同。结果是一个无意义的异常,而不是一个明确的消息,说明数据源存在一些问题。我认为这是 Eclipselink 中的一个错误,因为至少它不应该抛出异常而不给出某种关于原因的线索,或者理想情况下具体说明发生了什么。

于 2017-08-31T08:54:58.810 回答