我刚进入docker并使用the official image设置了一个简单的mysql 5.5。这是我的相关文件。
#Dockerfile
FROM mysql:5.5
ENV MYSQL_ROOT_PASSWORD password
#docker-compose.yml
db:
build: .
现在我运行docker-compose build
后跟docker-compose up
它给出了以下输出
db_1 | 150828 14:04:17 [Note] mysqld: ready for connections.
db_1 | Version: '5.5.45' socket: '/tmp/mysql.sock' port: 3306 MySQL Community Server (GPL)
现在在另一个终端我运行docker-compose run db bash
并进入bash shell。但是在这个shell中,如果我尝试连接mysql客户端,我会收到错误。
root@94a43b1f5be0:/# mysql -u root -p
ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/tmp/mysql.sock' (2)
同样的事情适用于普通的老码头工人。 示例(使用相同的Docker文件):
docker build -t my-new-image .
docker run --name my-new-image-container -d my-new-image
docker exec -it my-new-image-container bash
root@8408282d162f:/# mysql -u root -p
mysql>
我在使用docker-compose做错了什么。如何连接到我正在运行的mysql容器并触发一些查询。任何帮助将不胜感激。
答案 0 :(得分:2)
使用docker-compose run
实际上会启动一个新容器,而不是连接到现有容器。在这种情况下,您已使用bash
覆盖了命令,因此mysql服务器尚未启动。
您可以做的只是docker exec
docker-compose ps
给出的容器{/ 1}}。
docker-compose.yml
的环境变量中设置密码。这也具有不将密码烘焙到图像中的优点。