java - 为什么 Wildfly 10 在部署时给我 "Empty name segment is not allowed for jdbc:postgresql"?

标签 java postgresql jdbc jboss

我有一个将 ejb 模块打包到 ear 文件中的应用程序。当我想部署到 Wildfly 时,出现以下错误。根据this使用 standalone.xml 文件发布不正确的内容。我检查过我的,没问题。

谁能告诉我这里的问题是什么?

持久性.xml

<?xml version="1.0" encoding="UTF-8"?>
<persistence xmlns="http://java.sun.com/xml/ns/persistence" version="2.0">
    <persistence-unit name="PU" transaction-type="JTA">
        <jta-data-source>jdbc:postgresql://localhost:5432/Database</jta-data-source>
        <properties>
            <property name="hibernate.connection.username" value="postgres"/>
            <property name="hibernate.connection.password" value="postgres" />
            <property name="hibernate.show_sql" value="true" />
            <property name="hibernate.format_sql" value="true"/>
            <property name="hibernate.dialect" value="org.hibernate.dialect.PostgreSQL95Dialect"/>
        </properties>
    </persistence-unit>
</persistence>

Wildfly 控制台日志。

16:41:50,200 ERROR [org.jboss.msc.service.fail] (MSC service thread 1-2) MSC000001: Failed to start service jboss.deployment.subunit."DigitalLibrary.MasterData.Dataservice.ear"."MasterData.Ejb.jar".FIRST_MODULE_USE: org.jboss.msc.service.StartException in service jboss.deployment.subunit."DigitalLibrary.MasterData.Dataservice.ear"."MasterData.Ejb.jar".FIRST_MODULE_USE: WFLYSRV0153: Failed to process phase FIRST_MODULE_USE of subdeployment "MasterData.Ejb.jar" of deployment "DigitalLibrary.MasterData.Dataservice.ear"
        at org.jboss.as.server.deployment.DeploymentUnitPhaseService.start(DeploymentUnitPhaseService.java:154)
        at org.jboss.msc.service.ServiceControllerImpl$StartTask.startService(ServiceControllerImpl.java:1948)
        at org.jboss.msc.service.ServiceControllerImpl$StartTask.run(ServiceControllerImpl.java:1881)
        at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142)
        at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617)
        at java.lang.Thread.run(Thread.java:745)
Caused by: java.lang.IllegalArgumentException: Empty name segment is not allowed for jdbc:postgresql:
        at org.jboss.msc.service.ServiceName.of(ServiceName.java:90)
        at org.jboss.msc.service.ServiceName.append(ServiceName.java:117)
        at org.jboss.as.naming.deployment.ContextNames.buildServiceName(ContextNames.java:203)
        at org.jboss.as.naming.deployment.ContextNames$BindInfo.<init>(ContextNames.java:215)
        at org.jboss.as.naming.deployment.ContextNames$BindInfo.<init>(ContextNames.java:206)
        at org.jboss.as.naming.deployment.ContextNames.bindInfoFor(ContextNames.java:136)
        at org.jboss.as.naming.deployment.ContextNames.bindInfoForEnvEntry(ContextNames.java:190)
        at org.jboss.as.jpa.processor.PersistenceUnitServiceHandler.deployPersistenceUnitPhaseOne(PersistenceUnitServiceHandler.java:502)
        at org.jboss.as.jpa.processor.PersistenceUnitServiceHandler.addPuService(PersistenceUnitServiceHandler.java:276)
        at org.jboss.as.jpa.processor.PersistenceUnitServiceHandler.handleJarDeployment(PersistenceUnitServiceHandler.java:163)
        at org.jboss.as.jpa.processor.PersistenceUnitServiceHandler.deploy(PersistenceUnitServiceHandler.java:133)
        at org.jboss.as.jpa.processor.PersistenceBeginInstallProcessor.deploy(PersistenceBeginInstallProcessor.java:52)
        at org.jboss.as.server.deployment.DeploymentUnitPhaseService.start(DeploymentUnitPhaseService.java:147)
        ... 5 more

最佳答案

“jta-data-source 指向该持久性单元映射到的数据库的 JNDI 名称。”来自链接https://docs.jboss.org/jbossas/docs/Server_Configuration_Guide/4/html/ch01s02s01.html

但是您已经配置了 connection-url。可以从 jboss 管理页面或通过修改独立文件来配置数据源。一个例子 - https://developer.jboss.org/wiki/JBossAS7-DatasourceConfigurationForPostgresql?_sscc=t

关于java - 为什么 Wildfly 10 在部署时给我 "Empty name segment is not allowed for jdbc:postgresql"?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44474669/

相关文章:

postgresql - 如何获得更改运行时参数的权限?

java - JDBC session 和 Oracle 进程之间的关系

java - 使用 JDBC 从长字符串创建 CLOB

java - 多次使用准备好的语句是否资源安全?

java - 线程中出现异常 "main"java.lang.UnsatisfiedLinkError : no jniopencv_core in java. library.path

java - 在 Java 中以 HTTP 格式获取日期

c# - 无法将 PostgreSQL 中的文件作为大对象存储然后读取

java - 如何从未被 hibernate 映射的表中添加带 hibernate 的外键?

java - 如何使用 jruby 创建 servlet(使用 jetty 运行)?

java - "Could not load library: gstreamer"在 Intellij IDEA 中设置 gstreamer 时