用于创建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所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)