我在 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/

10-16 15:58