Postgresql docker 容器连接失败
Postgresql docker container connection failure
我正在使用这行代码尝试连接(w/ jdbc)到 psql docker 容器:
Connection conn = DriverManager.getConnection(
"jdbc:postgresql://localhost:5431/postgres?allowPublicKeyRetrieval=true&useSSL=false&serverTimezone=UTC",
"postgres", "postgres");
数据库名称、用户名和密码都是postgres。
容器创建于
docker run --name practice -e POSTGRES_PASSWORD=postgres -p 5431:5431 postgres
此处错误:
org.postgresql.util.PSQLException: The connection attempt failed.
at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:150)
at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:66)
at org.postgresql.jdbc2.AbstractJdbc2Connection.<init>(AbstractJdbc2Connection.java:125)
at org.postgresql.jdbc3.AbstractJdbc3Connection.<init>(AbstractJdbc3Connection.java:30)
at org.postgresql.jdbc3g.AbstractJdbc3gConnection.<init>(AbstractJdbc3gConnection.java:22)
at org.postgresql.jdbc4.AbstractJdbc4Connection.<init>(AbstractJdbc4Connection.java:30)
at org.postgresql.jdbc4.Jdbc4Connection.<init>(Jdbc4Connection.java:24)
at org.postgresql.Driver.makeConnection(Driver.java:393)
at org.postgresql.Driver.connect(Driver.java:267)
at java.sql/java.sql.DriverManager.getConnection(DriverManager.java:677)
at java.sql/java.sql.DriverManager.getConnection(DriverManager.java:228)
at com.dehmer.JdbcSelectTest.main(JdbcSelectTest.java:9)
Caused by: java.io.EOFException
at org.postgresql.core.PGStream.ReceiveChar(PGStream.java:276)
at org.postgresql.core.v3.ConnectionFactoryImpl.doAuthentication(ConnectionFactoryImpl.java:269)
at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:108)
... 11 more
docker 容器 ls:
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
be8931d1621c postgres "docker-entrypoint.s…" About an hour ago Up About an hour 0.0.0.0:5431->5431/tcp, 5432/tcp practice
同一行代码将连接到我刚才制作的另一个 psql 容器,我能看到它们之间的唯一区别是另一个在端口 5432 上(所以只需在 getConnection args 中使用 5432 和运行 我的旧容器可以正常工作)。我可以通过 docker cli 访问数据库,它是 运行。但我要补充一点,我对网络概念还很陌生,所以我很容易忽略这里的一些东西。非常感谢任何帮助。
我认为您希望容器端口 5432
是默认的 postgres 端口发布 到本地主机端口 5431
。而不是
docker run --name practice -e POSTGRES_PASSWORD=postgres -p 5431:5431 postgres
使用
docker run --name practice -e POSTGRES_PASSWORD=postgres -p 5431:5432 postgres
我正在使用这行代码尝试连接(w/ jdbc)到 psql docker 容器:
Connection conn = DriverManager.getConnection(
"jdbc:postgresql://localhost:5431/postgres?allowPublicKeyRetrieval=true&useSSL=false&serverTimezone=UTC",
"postgres", "postgres");
数据库名称、用户名和密码都是postgres。 容器创建于
docker run --name practice -e POSTGRES_PASSWORD=postgres -p 5431:5431 postgres
此处错误:
org.postgresql.util.PSQLException: The connection attempt failed.
at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:150)
at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:66)
at org.postgresql.jdbc2.AbstractJdbc2Connection.<init>(AbstractJdbc2Connection.java:125)
at org.postgresql.jdbc3.AbstractJdbc3Connection.<init>(AbstractJdbc3Connection.java:30)
at org.postgresql.jdbc3g.AbstractJdbc3gConnection.<init>(AbstractJdbc3gConnection.java:22)
at org.postgresql.jdbc4.AbstractJdbc4Connection.<init>(AbstractJdbc4Connection.java:30)
at org.postgresql.jdbc4.Jdbc4Connection.<init>(Jdbc4Connection.java:24)
at org.postgresql.Driver.makeConnection(Driver.java:393)
at org.postgresql.Driver.connect(Driver.java:267)
at java.sql/java.sql.DriverManager.getConnection(DriverManager.java:677)
at java.sql/java.sql.DriverManager.getConnection(DriverManager.java:228)
at com.dehmer.JdbcSelectTest.main(JdbcSelectTest.java:9)
Caused by: java.io.EOFException
at org.postgresql.core.PGStream.ReceiveChar(PGStream.java:276)
at org.postgresql.core.v3.ConnectionFactoryImpl.doAuthentication(ConnectionFactoryImpl.java:269)
at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:108)
... 11 more
docker 容器 ls:
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
be8931d1621c postgres "docker-entrypoint.s…" About an hour ago Up About an hour 0.0.0.0:5431->5431/tcp, 5432/tcp practice
同一行代码将连接到我刚才制作的另一个 psql 容器,我能看到它们之间的唯一区别是另一个在端口 5432 上(所以只需在 getConnection args 中使用 5432 和运行 我的旧容器可以正常工作)。我可以通过 docker cli 访问数据库,它是 运行。但我要补充一点,我对网络概念还很陌生,所以我很容易忽略这里的一些东西。非常感谢任何帮助。
我认为您希望容器端口 5432
是默认的 postgres 端口发布 到本地主机端口 5431
。而不是
docker run --name practice -e POSTGRES_PASSWORD=postgres -p 5431:5431 postgres
使用
docker run --name practice -e POSTGRES_PASSWORD=postgres -p 5431:5432 postgres