Docker mysql无法连接到容器

时间:2016-04-02 20:55:57

标签: php mysql docker docker-compose

我有用于创建mysql映像的docker-compose文件并将端口暴露给3306,但是当我尝试安装CMS时,它给了我错误,它无法连接到数据库。我尝试扫描端口3306,它显示它已打开,因此mysql正在运行。

为什么两个泊坞容器不能相互看到?

这是我的docker-compose文件:

phpfpm:
  restart: always
  extends:
    file: php-fpm-5.6.yml
    service: phpfpm
  links:
    - db:db

nginx:
  restart: always
  image: nginx
  ports:
    - "8000:80"
  links:
    - phpfpm:phpfpm
  volumes:
    - ./nginx/vhost.conf:/etc/nginx/conf.d/default.conf
    - ./app:/var/www/html
    - ./log/nginx:/var/log/nginx

db:
  restart: always
  image: mysql
  ports:
    - "3306:3306"
  environment:
    MYSQL_ROOT_PASSWORD: 123456
    MYSQL_USER: user
    MYSQL_PASSWORD: password
    MYSQL_DATABASE: database

1 个答案:

答案 0 :(得分:20)

要连接到数据库,请使用您提供的链接/别名作为主机名。因此,CMS可以使用db作为主机名和端口3306连接到MySQL。

您将无法连接到localhost或127.0.0.1,因为“localhost”是每个容器中的localhost,因此,在phpfpm容器中使用“localhost”会尝试连接到phpfpm容器内的MySQL数据库,但没有服务器在那里运行。

  

请注意,如果仅从链接容器内部连接到数据库,则不必发布"3306":"3306")MySQL端口。发布端口会在公共网络接口上公开MySQL,这可能是“因特网”