简单地说

我想在docker容器中运行mysql,并从我的主机连接到它。到目前为止,我所取得的最好成绩是:

ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/var/run/mysqld/mysqld.sock' (2)

更多的细节

我正在使用以下Dockerfile:

FROM ubuntu:14.04.3
RUN apt-get update && apt-get install -y mysql-server

# Ensure we won't bind to localhost only
RUN grep -v bind-address /etc/mysql/my.cnf > temp.txt \
  && mv temp.txt /etc/mysql/my.cnf

# It doesn't seem needed since I'll use -p, but it can't hurt
EXPOSE 3306

CMD /etc/init.d/mysql start && tail -F /var/log/mysql.log

在有这个文件的目录中,我可以成功地构建图像并运行它:

> docker build -t my-image .
> docker run -d -p 12345:3306 my-image

当我附加到图像时,它似乎工作得很好:

# from the host
> docker exec -it <my_image_name> bash

#inside of the container now
$ mysql -u root
Welcome to the MySQL monitor.  Commands end with ; or \g.
[...]

然而,我并没有从主持人那里得到太多的成功:

> mysql -P 12345 -uroot
ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/var/run/mysqld/mysqld.sock' (2)

更多细节

我看到有一个问题看起来像我的。然而,这是不一样的(它没有任何答案) 我已经看到有专门的mysql映像,但我没有更多的成功与他们 我的grep -v可能感觉很奇怪。诚然,也许有更清洁的方法。但是当我附加我的图像时,我可以观察到它实际上按预期工作(即:删除绑定地址)。我可以在容器/var/log/mysql/error.log中看到:

服务器主机名(bind-address): '0.0.0.0';端口:3306 - '0.0.0.0'解析为'0.0.0.0'; 在IP: '0.0.0.0'上创建的服务器套接字。


当前回答

我通过在我的服务器上运行一个临时的docker容器来做到这一点,这样我就不必担心主机上安装了什么。首先,我定义了我需要什么(你应该根据自己的目的进行修改):

export MYSQL_SERVER_CONTAINER=mysql-db
export MYSQL_ROOT_PASSWORD=pswd 
export DB_DOCKER_NETWORK=db-net
export MYSQL_PORT=6604

我总是创建一个新的docker网络,其他容器将需要:

docker network create --driver bridge $DB_DOCKER_NETWORK

启动mySQL数据库服务器:

docker run --detach --name=$MYSQL_SERVER_CONTAINER --net=$DB_DOCKER_NETWORK --env="MYSQL_ROOT_PASSWORD=$MYSQL_ROOT_PASSWORD" -p ${MYSQL_PORT}:3306 mysql

获取新服务器容器的IP地址

export DBIP="$(docker inspect ${MYSQL_SERVER_CONTAINER} | grep -i 'ipaddress' | grep -oE '((1?[0-9][0-9]?|2[0-4][0-9]|25[0-5])\.){3}(1?[0-9][0-9]?|2[0-4][0-9]|25[0-5])')"

打开服务器的命令行接口:

docker run -it -v ${HOST_DATA}:/data --net=$DB_DOCKER_NETWORK --link ${MYSQL_SERVER_CONTAINER}:mysql --rm mysql sh -c "exec mysql -h${DBIP} -uroot -p"

当您退出mySQL界面时,最后一个容器将自行删除,而服务器将继续运行。您还可以在服务器和主机之间共享卷,以便更容易地导入数据或脚本。希望这能有所帮助!

其他回答

在终端运行docker exec -it container_name /bin/bash 然后:mysql

我通过在我的服务器上运行一个临时的docker容器来做到这一点,这样我就不必担心主机上安装了什么。首先,我定义了我需要什么(你应该根据自己的目的进行修改):

export MYSQL_SERVER_CONTAINER=mysql-db
export MYSQL_ROOT_PASSWORD=pswd 
export DB_DOCKER_NETWORK=db-net
export MYSQL_PORT=6604

我总是创建一个新的docker网络,其他容器将需要:

docker network create --driver bridge $DB_DOCKER_NETWORK

启动mySQL数据库服务器:

docker run --detach --name=$MYSQL_SERVER_CONTAINER --net=$DB_DOCKER_NETWORK --env="MYSQL_ROOT_PASSWORD=$MYSQL_ROOT_PASSWORD" -p ${MYSQL_PORT}:3306 mysql

获取新服务器容器的IP地址

export DBIP="$(docker inspect ${MYSQL_SERVER_CONTAINER} | grep -i 'ipaddress' | grep -oE '((1?[0-9][0-9]?|2[0-4][0-9]|25[0-5])\.){3}(1?[0-9][0-9]?|2[0-4][0-9]|25[0-5])')"

打开服务器的命令行接口:

docker run -it -v ${HOST_DATA}:/data --net=$DB_DOCKER_NETWORK --link ${MYSQL_SERVER_CONTAINER}:mysql --rm mysql sh -c "exec mysql -h${DBIP} -uroot -p"

当您退出mySQL界面时,最后一个容器将自行删除,而服务器将继续运行。您还可以在服务器和主机之间共享卷,以便更容易地导入数据或脚本。希望这能有所帮助!

如果你在docker-machine下运行docker ?

执行获取ip:

docker-machine ip <machine>

返回机器的IP并尝试连接mysql:

mysql -h<docker-machine-ip>

如果你使用“127.0.0.1”而不是localhost, mysql将使用tcp方法,你应该能够连接容器:

mysql -h 127.0.0.1 -P 3306 -u root

我能够连接mysql服务器5.7运行在我的主机使用下面的命令:

mysql -h 10.10.1.7 -P 3307 --protocol=tcp -u root -p  

这里的IP是我的主机IP和3307是在mysql docker转发的端口。输入命令后输入mysql的密码。就是这样。现在你已经从你的主机连接了mysql docker容器。