我在服务器上的docker容器中有Postgresql。我如何从外部,也就是从我的本地计算机连接到它?我应该应用什么设置来允许这样做?


当前回答

我知道这有点晚了,如果你像@Martin一样使用docker-compose的话

这些是帮助我连接到容器内psql的代码片段

Docker-compose db bash

root@de9f9358b70:/# psql -h db -U根-d posts_db

我不能评论,因为我没有50的声誉。希望这能有所帮助。

其他回答

你也可以通过docker exec命令访问:

$ docker exec -it postgres-container bash

# su postgres

$ psql

Or

$ docker exec -it postgres-container psql -U postgres

我已经在主机上运行postgres,不想允许网络连接,所以我在容器中运行临时postgres实例,并在两行中创建数据库:

# Run PostgreSQL
docker run --name postgres-container -e POSTGRES_PASSWORD=password -it -p 5433:5432 postgres

# Create database
docker exec -it postgres-container createdb -U postgres my-db

首先打开postgres的docker映像

docker exec -it <container_name>

然后你会得到根目录--root@868594e88b53:/# 它需要数据库连接

psql postgresql://<username>:<databasepassword>@postgres:5432/<database>

连接到运行postgres的本地容器

安装 psql

酿造搜索postgres

编译安装postgresql

2.

docker run --name postgres -e POSTGRES_DB=users \
  -e POSTGRES_USER=john \
  -e POSTGRES_PASSWORD=password \
  -p 5432:5432 -d postgres
psql --host=localhost --username=john --dbname=users

要从本地主机连接,你需要添加'——net host':

docker run --name some-postgres --net host -e POSTGRES_PASSWORD=mysecretpassword -d -p 5432:5432 postgres

你可以直接访问服务器而不使用exec从你的localhost,通过使用:

psql -h localhost -p 5432 -U postgres