加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

postgresql – 从Debian Docker容器连接到Windows Postgres

发布时间:2020-12-13 16:03:38 所属栏目:百科 来源:网络整理
导读:我在 Windows 10计算机上运行Postgres,我想从Docker容器连接到它.我遵循了许多来源的指示,事情应该有效,但事实并非如此. 用于创建Docker容器的命令行: docker run --rm -d --network=host --name mycontainer myimage 在postgresql.conf中: listen_address
我在 Windows 10计算机上运行Postgres,我想从Docker容器连接到它.我遵循了许多来源的指示,事情应该有效,但事实并非如此.

用于创建Docker容器的命令行:

docker run --rm -d --network=host --name mycontainer myimage

在postgresql.conf中:

listen_addresses = '*'

在pg_hba.conf中:

host    all             all             172.17.0.0/16           trust

在我的容器的bash shell中,我运行:

psql -h 127.0.0.1

我收到错误:

psql: could not connect to server: Connection refused

Is the server running on host “127.0.0.1” and accepting TCP/IP connections on port 5432?

毋庸置疑,Postgres肯定在我的计算机上运行,??我可以从本地应用程序查询它.我错过了什么?

解决方法

正如您所发现的那样,– network-host无法与Docker for Windows或Docker for Mac一起使用. It only works on Linux hosts.

此方案的一个选项可能是在容器中托管PostgreSql.如果使用docker-compose文件部署它们,则应该能够将两个单独的Docker容器(一个用于数据库,一个用于服务)组合在一起.默认情况下,docker-使用容器名称作为其DNS名称将will expose containers组合到同一个撰写文件中的其他人.

您还可以考虑将数据库包含在与服务相同的容器中,但我认为docker-compose解决方案更好,原因如下:

>它坚持每个容器的最佳实践,只有一个过程和一个单一的责任.>这意味着您可以轻松地更改和重新部署服务,而无需重新创建数据库容器.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读