Docker“无法通过套接字连接到本地MySQL服务器”

时间:2017-05-09 13:21:11

标签: mysql docker containers

我是Docker的新手。我设法用我想要的东西建立一个图像(CentOS与Apache,PHP,MySQL,MailHog和supervisord。)它工作正常。

现在,我要做的是将我的图像(一个容器)转换为多个图像/容器:一个用于web,一个用于db等。

我设法构建了这些不同的图片,但是我无法通过webdbdocker-composer.yml联系在一起。这就是我所拥有的:

web:
  container_name: centosweb
  image: fab/centosweb
  ports:
    - "80:80"
  volumes:
    # Single files
    - ./config/httpd.conf:/etc/httpd/conf/httpd.conf
    # Directories
    - ./vhosts:/var/www/html
    - /Users/fabien/Dropbox/AppData/XAMPP/web/bilingueanglais/public_html:/var/www/html/bilingueanglais
    - ./logs/apache:/etc/httpd/logs # This will include access_log(s) and error_log(s), including PHP errors.
  links:
    - db
db:
  container_name: centosdb
  image: fab/centosdb
  volumes:
    # Single files
    - ./config/my.cnf:/etc/my.cnf
    # Directories
    - ./mysqldata:/var/lib/mysql
    - ./logs/mysql:/var/log/mysql

docker ps的输出是:

CONTAINER ID        IMAGE               COMMAND             CREATED             STATUS              PORTS                                  NAMES
95048de7a6c4        fab/centosweb       "supervisord -n"    14 minutes ago      Up 14 minutes       22/tcp, 8025/tcp, 0.0.0.0:80->80/tcp   centosweb
eab3047a2dde        fab/centosdb        "supervisord -n"    14 minutes ago      Up 14 minutes       22/tcp, 80/tcp, 8025/tcp               centosdb

尝试连接到我的虚拟主机时,出现数据库错误:

  

无法通过套接字'/var/lib/mysql/mysql.sock'连接到本地MySQL服务器

但是,我可以连接到centosdb,输入MySQL,并确认数据库在那里(即:数据库服务器本身运行正常。)

到目前为止,我的理解是我错过了告诉MySQL允许来自web应用程序而不是默认行为(来自localhost的连接)的方法。)但是,我对如何做到这一点很困惑。

这与this question非常相似,但后者不包含我正在寻找的具体内容。

编辑:Dockerfile容器db的来源。

FROM centos:6.9


# Install MySQL (MariaDB)
# Warning: the repo is super slow in my experience (e.g.: 15 min for 191 MB.)
RUN yum -y update
ADD MariaDB.repo /etc/yum.repos.d/MariaDB.repo
RUN yum install -y MariaDB-server MariaDB-client


# Install supervisord
# EPEL = Extra Packages for Enterprise Linux -- used for python
RUN rpm -Uvh http://dl.fedoraproject.org/pub/epel/6/x86_64/epel-release-6-8.noarch.rpm
RUN yum install -y python-pip && pip install "pip>=1.4,<1.5" --upgrade
RUN pip install supervisor



##
# START SERVER
# port 22: SSH
# port 80: TCP, HTTP
# port 8025: MailHog UI (web)
##
ADD supervisord-db.conf /etc/supervisord.conf
EXPOSE 22 80 8025
CMD ["supervisord", "-n"]



# MEMO · BUILD THE IMAGE:
# docker build -t fab/centosdb .

1 个答案:

答案 0 :(得分:1)

您的应用程序如何配置为与MySQL通信?而不是localhost:3306,您需要告诉您的应用程序在db:3306连接到MySQL。该链接将MySQL容器的DNS名称设置为db,您的应用程序应该能够解析此DNS名称以获取MySQL容器的正确IP地址。