当前位置: 首页 > 知识库问答 >
问题:

允许docker容器连接到本地/主机postgres数据库

岑畅
2023-03-14

我最近一直在玩Docker和QGIS,并按照本教程中的说明安装了一个容器。

我运行的是Ubuntu 14.04;Postgres 9.3

共有1个答案

郜联
2023-03-14
  1. 使用172.17.0.0/16作为IP地址范围,而不是172.17.0.0/32.
  2. 不要使用localhost连接到主机上的PostgreSQL数据库,而是使用主机的IP。为了保持容器的可移植性,使用--add-host=database: 标志启动容器,并使用database作为连接到PostgreSQL的主机名。
  3. 确保PostgreSQL配置为侦听所有IP地址上的连接,而不仅仅是localhost上的连接。在PostgreSQL的配置文件中查找listen_addresses设置,通常在/etc/PostgreSQL/9.3/main/PostgreSQL L.conf(归功于@dazmonorton).
  4. 中找到

172.17.0.0/32不是IP地址范围,而是单个地址(名称为172.17.0.0)。没有一个Docker容器会得到这个地址,因为它是Docker桥(docker0)接口的网络地址。

当Docker启动时,它将创建一个新的桥接网络接口,您可以在调用IP a时轻松地看到该接口:

$ ip a
...
3: docker0: <NO-CARRIER,BROADCAST,MULTICAST,UP> mtu 1500 qdisc noqueue state DOWN 
    link/ether 56:84:7a:fe:97:99 brd ff:ff:ff:ff:ff:ff
    inet 172.17.42.1/16 scope global docker0
       valid_lft forever preferred_lft forever

IP地址是随机分配的,但没有任何附加配置,它将始终位于172.17.0.0/16网络中。对于每个Docker容器,将从该范围中分配一个随机地址。

这意味着,如果您想从所有可能的容器授予对数据库的访问权限,请使用172.17.0.0/16

 类似资料:
  • 问题内容: 我最近一直在研究Docker和QGIS,并按照本教程中的说明安装了一个容器。 尽管我无法连接到包含我的所有GIS数据的localhost postgres数据库,但一切工作都很好。我认为这是因为我的postgres数据库未配置为接受远程连接,并且已经按照本文中的说明编辑了postgres conf文件以允许远程连接。 尝试连接到在Docker中运行QGIS的数据库时,我仍然收到错误消息

  • 以下图片: 当我运行这个命令时,我可以在http://localhost:4444/上看到Selenium 任何帮助让这两种方式中的任何一种有效。

  • 问题内容: 我正在运行一个docker mysql映像,以下是docker-compose.yml文件的外观: 这很好。 我的问题是:如何从主机(我的Macbook)上的命令行mysql客户端连接到在该容器上运行的MySQL实例? 澄清: 我有一台装有Docker的Macbook 我有一个带有mysql的docker容器 我想从Macbook的终端连接到上述容器上运行的mysql实例 我不想使用命

  • 在将Django docker容器连接到Postgres数据库时,我收到以下错误。 下面是运行容器的Dockerfile pg_hba.conf->宿主all all 0.0.0.0/0 md5 我已经读到上面的以下细节打开数据库上的连接。

  • 澄清: 我有一台安装了Docker的macbook 我有一个带有MySQL的docker容器 我想从MacBook上的终端连接到在上述容器上运行的mysql实例 我不想使用命令来实现此操作。相反,我想直接从终端使用客户机(而不通过docker容器隧道进入)。 我没有在本地运行MySQL,所以端口3306应该是打开的,可以随时使用。 我用来启动容器的命令是:

  • 我有一个运行java进程的docker容器,我试图将该进程连接到本地主机上运行的rabbitmq。 以下是我到目前为止所做的步骤: null 能够ping local-ip和curl rabbitmq admin api [{“名称”:“/”,“跟踪”:false}] 当我试图从容器内部telnet时,我得到 由:java.net.ConnectException:在java.net.plains