我最近一直在玩Docker和QGIS,并按照本教程中的说明安装了一个容器。
我运行的是Ubuntu 14.04;Postgres 9.3
172.17.0.0/16
作为IP地址范围,而不是172.17.0.0/32
.localhost
连接到主机上的PostgreSQL数据库,而是使用主机的IP。为了保持容器的可移植性,使用--add-host=database:
标志启动容器,并使用database
作为连接到PostgreSQL的主机名。localhost
上的连接。在PostgreSQL的配置文件中查找listen_addresses
设置,通常在/etc/PostgreSQL/9.3/main/PostgreSQL L.conf
(归功于@dazmonorton).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