我在 vm 中安装了 Ubuntu 16.04,我正在尝试在 docker 容器中运行一个应用程序并将其连接到主机上的 MySQL 数据库
我有这样的东西.. 在我有 MySQL 的主机上:
当我尝试将我的应用程序连接到 MySQL 时,我得到了这个:
我使用 docker-compose 执行我的应用程序:
version: '2'
services:
exo:
image: exoplatform/exo-community:5.0
environment:
EXO_DB_TYPE: mysql
EXO_DB_NAME: user
EXO_DB_USER: root
EXO_DB_PASSWORD: "my-pass"
EXO_DB_HOST: "127.0.0.1"
EXO_ADDONS_LIST: exo-jdbc-driver-mysql
expose:
- "8080"
- "3306"
ports:
- "8080:8080"
volumes:
- exo_data:/srv/exo
- exo_logs:/var/log/exo
volumes:
exo_data:
external:
name: exo_data
exo_logs:
external:
name: exo_logs
networks:
default:
driver: bridge
如您所见,我尝试连接到 MySQL 默认端口...我刚刚看到 3306 端口正在监听主机。
我还尝试添加以下行(在另一篇文章中看到)
在 my.cnf 中,我有绑定(bind)地址 0.0.0.0。
并且 MySQL 正在运行:
root@xxx/# mysqladmin -u root -p status
Uptime: 4784 Threads: 4 Questions: 17 Slow queries: 0 Opens: 114 Flush tables: 1 Open tables: 33 Queries per second avg: 0.003
我在桥上使用 docker,所以我想我只需要在 docker composer 上添加端口即可连接 docker 和主机。但似乎没有任何效果。有人可以指出我正确的方向吗?
最佳答案
问题是您正在尝试使用 localhost
从容器连接到主机。这将不起作用,因为容器有自己的 ip,本地主机将访问容器而不是主机。
从容器连接到主机是 stackoverflow 上一个非常常见的问题,你可以在 From inside of a Docker container, how do I connect to the localhost of the machine? 中找到很多答案
最简单的方法(虽然不推荐)是在 docker-compose 文件中使用 network_mode: host
。在这种情况下,容器将与主机共享网络,本地主机也会访问主机。
关于mysql - Docker 将应用程序连接到 mysql 主机,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/48448853/