[英]MySql docker container, via terminal works, via docker-compose no
[英]How to run a MySQL command terminal in Docker, with a docker-compose server
假设我有以下撰写文件:
networks:
my_network:
services:
...
mysql:
container_name: "mysql"
image: "mysql:5.7"
volumes:
- ./mysql.cnf:/etc/mysql/conf.d/mysql.cnf
environment:
MYSQL_ROOT_PASSWORD: "password"
MYSQL_USER: "user"
MYSQL_PASSWORD: "password"
MYSQL_DATABASE: "test-db"
ports:
- "3306:3306"
restart: always
networks:
- my_network
一旦我运行docker-compose up
,我的服务就会启动,我可以看到我的 MySQL 服务器已准备好接受连接。 现在我需要做什么才能从容器“外部”访问 mysql 终端提示符? 我记得看到一位老师运行另一个 docker 容器(从新终端),并访问 MySQL 命令提示符,使他能够从另一个终端 window 手动管理数据库,但我完全记得命令。
我尝试像这样运行一个新的 Docker 容器:
docker run -it --rm --name mysqlterm \
--network="compose_project_my_network" \
--link mysql mysql:5.7 \
sh -c 'exec mysql \
-h "localhost" -P 3306" \
-uroot \
-ppassword'
但不幸的是,容器无法连接到 MySQL 服务器,给我以下错误: ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/var/run/mysqld/mysqld.sock' (2)
.
我猜“localhost”或3306端口错了? 我应该在这些参数中输入什么?
提前感谢您的回答:)
你需要一个普通的MySQL客户端; 如果您的主机的 package 管理器(Debian/Ubuntu APT,MacOS Homebrew,...)有一个名为mysql-client
的打包,就是这样。
当您运行mysql
时,该工具不会将localhost
解释为主机名,而是将其解释为使用 Unix 套接字的信号,因此您需要使用相应的 ZA12A3079E14CED46E69BA52B8A90B211AZ 来代替。地址。1。 (如果数据库在不同的系统上运行,请使用其 DNS 名称或 IP 地址:这与直接在 Docker 之外的主机上运行数据库没有区别。)
所以从主机运行:
mysql -h 127.0.0.1 -u root -p
默认端口 3306 与发布的ports:
,系统将提示您以交互方式输入密码。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.