从Docker容器连接到localhost上的MySQL

我在本地主机上运行mysql,可以通过运行以下命令进行连接:

mysql -h 127.0.0.1 -P 3306 -u root -p

我还使用以下命令运行了Docker容器:

docker run -tid -v $(pwd):/code -p 3306:3306 -p 5000:5000 --name container container

我想从docker容器访问Mysql数据库。所以我也从docker容器输入:

mysql -h 127.0.0.1 -P 3306 -u root -p

但这给了我错误:

ERROR 2003 (HY000): Can't connect to MySQL server on '127.0.0.1' (111)

我究竟做错了什么?端口似乎是正确的。 ifconfig在码头工人的 输出:

eth0      Link encap:Ethernet  HWaddr 02:42:ac:11:00:02  

inet addr:172.17.0.2 Bcast:0.0.0.0 Mask:255.255.0.0

inet6 addr: fe80::42:acff:fe11:2/64 Scope:Link

UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1

RX packets:1780 errors:0 dropped:0 overruns:0 frame:0

TX packets:977 errors:0 dropped:0 overruns:0 carrier:0

collisions:0 txqueuelen:0

RX bytes:2225781 (2.2 MB) TX bytes:56572 (56.5 KB)

lo Link encap:Local Loopback

inet addr:127.0.0.1 Mask:255.0.0.0

inet6 addr: ::1/128 Scope:Host

UP LOOPBACK RUNNING MTU:65536 Metric:1

RX packets:28 errors:0 dropped:0 overruns:0 frame:0

TX packets:28 errors:0 dropped:0 overruns:0 carrier:0

collisions:0 txqueuelen:1

RX bytes:1400 (1.4 KB) TX bytes:1400 (1.4 KB)

回答:

即使将MySQL配置为侦听所有接口,然后从容器通过非环回IP访问MySQL,您仍可能会发现Docker的路由,NAT和防火墙规则不允许您访问主机上运行的服务。快速的解决方法是使用以下命令在主机网络堆栈上运行容器:

docker run -tid -v $(pwd):/code -p 3306:3306 -p 5000:5000 \

--name container --net host container

您还可以将MySQL移动到运行在同一Docker网络上的容器内,然后使用Docker的DNS服务发现通过容器名称访问它。

以上是 从Docker容器连接到localhost上的MySQL 的全部内容, 来源链接: utcz.com/qa/424801.html

回到顶部