database - 当我在持久性 xml 中提供另一个端口 5432 时,连接到端口 1,527 上的服务器 localhost 时出错
问题描述
在 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.
解决方案
解决方案是在 glassfish 中为 postgresql 创建一个 jdbc 连接池。去做这个:
- 在此处下载 postgresql jdbc 驱动并将其放置在 glassfish5\glassfish\domains\domain1\lib 中。
- 重新启动你的玻璃鱼。
- 转到 glassfish 管理网页 localhost:4848。
- 转到 JDBC -> JDBC 连接池
- 单击新建以创建一个。
- PoolName =你想要的任何东西
- 资源类型 = javax.sql.ConnectionPoolDataSource
- 数据源类名 = org.postgresql.jdbc3.Jdbc3PoolingDataSource
- 对于属性,创建这些:
- user = postgres,你的用户
- portNumber = 5432,数据库的端口号
- 密码 =连接数据库的密码
- databaseName = 组合,要连接的数据库名称
- servername = localhost,您的服务器名称
- Ping 进行测试。
- 保存。
- 转到 JDBC -> 资源并编辑 jdbc/__default。
- 将池名称设置为您创建的池的池名称。
推荐阅读
- r - Sum Country Total
- javascript - Socket not working between react and node.js
- database - How to paginate, and filter at the same time?
- javascript - 赛普拉斯:拦截一条不存在的路线
- c++ - 不存在从 std::shared_ptr 到 std::shared_ptr 的合适的用户定义转换
- python - 如何在 Django 中一个类的多个函数之间共享一个变量?
- powershell - powershell-get-random-and-rename 该目录下的所有内容,包括子目录下的所有文件
- python - ML BoW:对单词变量的预测包的每个集群进行采样,以查看哪些单词最重复地聚集在一起
- arrays - 在 C 中使用 calloc() 和 free()
- javascript - 为什么 CSS 在某些路由上不起作用?