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

postgresql – 从Debian Docker容器连接到Windows Postgres,第1张

概述我在 Windows 10计算机上运行Postgres,我想从Docker容器连接到它.我遵循了许多来源的指示,事情应该有效,但事实并非如此. 用于创建Docker容器的命令行: docker run --rm -d --network=host --name mycontainer myimage 在postgresql.conf中: listen_addresses = '*' 在pg_hba 我在 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解决方案更好,原因如下:

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

总结

以上是内存溢出为你收集整理的postgresql – 从Debian Docker容器连接到Windows Postgres全部内容,希望文章能够帮你解决postgresql – 从Debian Docker容器连接到Windows Postgres所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/1161766.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-01
下一篇 2022-06-01

发表评论

登录后才能评论

评论列表(0条)

保存