【问题标题】:Glassfish server does not start. NullPointeExceptionGlassfish 服务器无法启动。空指针异常
【发布时间】:2018-05-07 13:46:55
【问题描述】:

我刚刚下载了 GlassFish 5.0 存档 - 完整平台,解压缩,我通过命令行运行它。

asadmin 起始域

问题:

Exception in thread "main" java.lang.NullPointerException
at com.sun.enterprise.module.common_impl.AbstractModulesRegistryImpl.initializeServiceLocator(AbstractModulesRegistryImpl.java:152)
at com.sun.enterprise.module.common_impl.AbstractModulesRegistryImpl.newServiceLocator(AbstractModulesRegistryImpl.java:144)
at com.sun.enterprise.module.common_impl.AbstractModulesRegistryImpl.createServiceLocator(AbstractModulesRegistryImpl.java:218)
at com.sun.enterprise.module.common_impl.AbstractModulesRegistryImpl.createServiceLocator(AbstractModulesRegistryImpl.java:224)
at com.sun.enterprise.module.single.StaticModulesRegistry.createServiceLocator(StaticModulesRegistry.java:88)
at com.sun.enterprise.admin.cli.CLIContainer.getServiceLocator(CLIContainer.java:217)
at com.sun.enterprise.admin.cli.CLIContainer.getLocalCommand(CLIContainer.java:255)
at com.sun.enterprise.admin.cli.CLICommand.getCommand(CLICommand.java:231)
at com.sun.enterprise.admin.cli.AdminMain.executeCommand(AdminMain.java:371)
at com.sun.enterprise.admin.cli.AdminMain.doMain(AdminMain.java:306)
at org.glassfish.admin.cli.AsadminMain.main(AsadminMain.java:57)

我试图在文件 asenv.bat -> set path = C:/.../Java/bin 中设置路径 - 没有帮助。尝试启动:asadmin start-domain domain1 - 没有帮助。

已安装:jdk-9.0.1 8号也试过了,没用。怎么办???

【问题讨论】:

  • 你是认真的吗?请阅读我的描述!
  • 我已经这样做了,这就是我说Possible重复的原因。不是exact
  • 就像@Jonathan 说的,GlassFish 5 与 Java 9 不兼容,就我而言,我使用的是 GlassFish 5.1,从系统中清除/卸载 java 9 并安装 Java 8。确保在键入 java -version 在命令行你得到的响应是 java 8 而不是 9
  • Vifier Lockla 提供了解决方案:您只需指定要用于 Glassfih 或 Payara 的 Java 版本。 Payara 服务器也有同样的问题。

标签: java intellij-idea nullpointerexception glassfish payara


【解决方案1】:

好的,Glassfish 5.1 暂时不存在。使用此解决方案继续使用 Glassfish 5.0:

只需在位于此处的asenv.bat 文件中设置AS_JAVA 变量:C:\DEVENV\glassfish5\glassfish\config

要编辑的文件:添加最后一行

重新启动您的服务器....享受:

【讨论】:

  • 那行得通;但是你怎么到那里?提示是什么?很遗憾,这么受欢迎的服务器需要被黑才能启动。
  • @Vifier Lockla 是否可以将 jdk1.8.0_172 替换为 jdk1.8.0_221 ?我试过但没有为我工作。甚至尝试在 asenv.config 中输入相同的内容,但之前没有设置。
  • 对于 MacOS,更新 asenv.conf 文件 => AS_JAVA=/Library/Java/JavaVirtualMachines/jdk1.8.0_251.jdk/Contents/Home
【解决方案2】:

这似乎是这个问题 - https://github.com/eclipse-ee4j/glassfish/issues/22130

GlassFish 5 不能在 JDK9 上运行,但 GlassFish 6 可以在 JDK 11 上运行。

【讨论】:

  • 该死!真是浪费时间……浪费了 10 分钟试图弄清楚我到底做错了什么……
  • 自从 javaee 被移到 eclipse 保护伞下后,这个链接就失效了。这是新的链接。 github.com/eclipse-ee4j/glassfish/issues/22130
  • 截至目前,使用 5.1,仍然无法开箱即用(同样的例外)
【解决方案3】:

对我来说,@Vifier Lockla 所做的并不奏效。我不得不更改 linux mint 机器中的 path/glassfish5/glassfish/config/asenv.conf 文件。文件底部是jdk 1.8的路径,即

AS_JAVA="/usr/lib/jvm/jdk1.8.0_191"

【讨论】:

    【解决方案4】:

    GlassFish 5.1 也不适用于 Java 9 或更高版本。

    glassfish 5.1 还需要 java 8 以及 asenv.conf/bat 文件中的 AS_JAVA hack。

    【讨论】:

      【解决方案5】:

      编辑 asenv.bat put set AS_JAVA=/usr/lib/jvm/java-8-oracle 和 asenv.conf AS_JAVA="/usr/lib/jvm/java-8-oracle"

      有效

      【讨论】:

        【解决方案6】:

        当您从 Internet 下载 glassfish zip 文件并将其解压缩时。 阅读自述文件是一个好习惯。 在我的情况下,在自述文件中的“先决条件”标题下,它指定:GlassFish 5.0 需要 Oracle JDK 8 Update 144。 我按要求下载并安装了 JDK 8 更新 144。它立即起作用。我最初有 JDK 14.0.2,它显示@Aleksandr 发布的错误。

        【讨论】:

          【解决方案7】:

          我犯了与 OP 相同的错误,因为发行说明在发行说明中的​​标题 Required JDK Versions 下特别指出“GlassFish Server Open Source Edition Release 5.0 需要 Oracle JDK 8 Update 144 或更高版本” .

          但是您可以做的是下拉每个版本以查看 glassfish 5 将兼容的最新 jdk 版本,或者只需从 https://www.oracle.com/in/java/technologies/javase/javase8-archive-downloads.html 下载 Java SE Development Kit 8。

          您还必须在 asenv.bat 中添加 java 变量,正如 Vifier Lockla 所评论的那样。感谢 Vifier 的建议。

          【讨论】:

            猜你喜欢
            • 1970-01-01
            • 1970-01-01
            • 1970-01-01
            • 1970-01-01
            • 1970-01-01
            • 1970-01-01
            • 1970-01-01
            • 2018-06-21
            • 1970-01-01
            相关资源
            最近更新 更多