从Docker容器连接到localhost上的MySQL
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了从Docker容器连接到localhost上的MySQL,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1544字,纯文字阅读大概需要3分钟。
内容图文
我在我的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,您可能会发现dockers路由,nat和防火墙规则不允许您访问在主机上运行的服务.快速解决方法是在主机网络堆栈上运行容器:
docker run -tid -v $(pwd):/code -p 3306:3306 -p 5000:5000 --name container --net host container
您还可以在同一个docker网络上运行的容器中移动mysql,然后使用docker的DNS服务发现通过容器名称访问它.
内容总结
以上是互联网集市为您收集整理的从Docker容器连接到localhost上的MySQL全部内容,希望文章能够帮你解决从Docker容器连接到localhost上的MySQL所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。