当我在持久性 xml 中提供另一个端口 5432 时,连接到端口 1,527 上的服务器本地主机时出错

问题描述 投票:0回答:2

在 Java EE 中,我提供了 persistence.xml 并且已正确打包。

<?xml version="1.0" encoding="UTF-8" ?>
<persistence xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
             xsi:schemaLocation="http://java.sun.com/xml/ns/persistence http://java.sun.com/xml/ns/persistence/persistence_2_0.xsd"
             version="2.0" xmlns="http://java.sun.com/xml/ns/persistence">
    <persistence-unit name="ArticleManagement">
        <provider>org.eclipse.persistence.jpa.PersistenceProvider</provider>
        <class>com.pauljabines.portfolio.Article</class>
        <properties>
            <property name="javax.persistence.jdbc.url" value="jdbc:postgresql://localhost:5432/postgres" />
            <property name="javax.persistence.jdbc.driver" value="org.postgresql.Driver" />
            <property name="javax.persistence.jdbc.user" value="postgres" />
            <property name="javax.persistence.jdbc.password" value="************************" />
            <property name="eclipselink.logging.level" value="ALL" />
        </properties>
    </persistence-unit>
</persistence>

问题:有了这些连接属性,为什么 glassfish 会抛出错误并说无法连接到端口 1527?

这是一些堆栈跟踪:

org.glassfish.deployment.common.DeploymentException: Exception [EclipseLink-4002] (Eclipse Persistence Services - 2.7.0.v20170811-d680af5): org.eclipse.persistence.exceptions.DatabaseException
Internal Exception: java.sql.SQLException: Error in allocating a connection. Cause: Connection could not be allocated because: java.net.ConnectException : Error connecting to server localhost on port 1,527 with message Connection refused: connect.
database jakarta-ee glassfish database-connection persistence
2个回答
0
投票

解决方案是在glassfish中为postgresql创建一个jdbc连接池。为此:

  1. 在此处下载 postgresql jdbc 驱动程序并将其放置在 glassfish5\glassfish\domains\domain1\lib 中。
  2. 重新启动你的glassfish。
  3. 转到 glassfish 管理网页 localhost:4848。
  4. 转到 JDBC -> JDBC 连接池
  5. 单击“新建”以创建一个。
  6. 池名称 =
  7. 任何你想要的东西
  8. 资源类型 = javax.sql.ConnectionPoolDataSource
  9. 数据源类名 = org.postgresql.jdbc3.Jdbc3PoolingDataSource
  10. 对于属性,创建这些:
  11. 用户= postgres,
  12. 你的用户
  13. portNumber = 5432,
  14. 数据库的端口号
  15. 密码 =
  16. 连接数据库的密码
  17. databaseName = Portfolio,
  18. 要连接的数据库名称
  19. 服务器名称 = 本地主机,
  20. 您的服务器名称
  21. Ping 进行测试。
  22. 保存。
  23. 转到 JDBC -> 资源并编辑 jdbc/__default。
  24. 将池名称设置为您创建的池的池名称。

0
投票
我今天也遇到了这个问题,我发现如果您使用@PersistenceUnit注释,应用程序会尝试连接到Glassfish服务器的内部JavaDB,我不知道为什么。因此,您可以进入 Glassfish 安装的 bin 目录并运行“asadmin start-database”以在端口 1527 启动 JavaDB。然后您的应用程序应该运行。但我认为这很令人困惑。所以我建议在没有 @PersistenceUnit 注释的情况下工作。使用“Persistence.createEntityManagerFactory()”创建 EntityManagerFactory。这无需启动 JavaDB 即可工作。

© www.soinside.com 2019 - 2024. All rights reserved.