加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 服务器 > 安全 > 正文

从docker容器连接到localhost上的Mysql

发布时间:2020-12-16 03:42:19 所属栏目:安全 来源:网络整理
导读:我在我的localhost上运行了mysql 我可以通过运行来连接它: mysql -h 127.0.0.1 -P 3306 -u root -p 我还用命令运行了docker container: docker run -tid -v $(pwd):/code -p 3306:3306 -p 5000:5000 --name container container 我想从docker容器访问我的M

我在我的localhost上运行了mysql
我可以通过运行来连接它:

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

我还用命令运行了docker container:

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)

我究竟做错了什么?端口似乎是正确的.
编辑1
在docker中输出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配置为侦听所有接口,然后从容器访问mysql来自非环回IP,您可能会发现docker路由,nat和防火墙规则不允许您访问在主机上运行的服务.快速解决方法是在主机网络堆栈上运行容器:

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

您还可以在同一个docker网络上运行的容器中移动mysql,然后使用docker的DNS服务发现通过容器名称访问它.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读