首页 > 解决方案 > 如何使用 Navicat 或 MySQL Workbench 将 MySQL 与 Docker 连接?

问题描述

我正在使用 MySQL Docker 映像,我可以使用mysqli_connect('mysql', 'docker', 'docker');php连接到这个 Docker

这里是docker ps

CONTAINER ID        IMAGE                   COMMAND                  CREATED             STATUS              PORTS                                          NAMES
c271f8e68378        afraidjpg/nginx:nginx   "nginx -g 'daemon of…"   2 hours ago         Up 2 hours          0.0.0.0:80->80/tcp, 0.0.0.0:10086->10086/tcp   nginx
92d7c923f777        afraidjpg/php:php56     "docker-php-entrypoi…"   2 hours ago         Up 2 hours          0.0.0.0:9000->9000/tcp                         php
68b818bd68c4        afraidjpg/mysql:mysql   "docker-entrypoint.s…"   2 hours ago         Up 2 hours          0.0.0.0:3306->3306/tcp, 33060/tcp              mysql

--link mysql在启动 PHP Docker 时使用选项。

MySQL Docker 的 IP 是172.17.0.2

我的mac的IP是192.168.1.50

这是mysql中的用户:

mysql> select User, Host from mysql.user;
+--------+-----------+
| User   | Host      |
+--------+-----------+
| docker | %         |
| root   | localhost |
+--------+-----------+
2 rows in set (0.00 sec)

然后我尝试用navicat和mysql-workbench连接mysql

主机:192.168.1.50,用户:码头工人,通过:码头工人Access denied for user 'docker'@'%%' (using password: YES)

主机:127.0.0.1,用户:码头工人,通过:码头工人Access denied for user 'docker'@'%%' (using password: YES)

主机:172.17.0.2,用户:码头工人,通过:码头工人Can't connect to MySQL server on '172.17.0.2

都得到错误Access denied for user 'docker'@'%%' (using password: YES)

如果我试图将用户从docker更改为root,则错误变为Access denied for user 'docker'@'172.17.0.1' (using password: YES)

我之前找到了一些文章,并按照他们的步骤进行操作,但总是失败。我不知道我错在哪里

这是一些截图

在此处输入图像描述

在此处输入图像描述

在此处输入图像描述

更新 我无法从本地 ping 到 docker,并且 docker 中没有 ping 命令,所以我无法进行从 docker ping 到本地的测试

zk ~/Documents/PHP/www/docker $ ping 172.17.0.2
PING 172.17.0.2 (172.17.0.2): 56 data bytes
Request timeout for icmp_seq 0
Request timeout for icmp_seq 1
Request timeout for icmp_seq 2
Request timeout for icmp_seq 3

更多更新

我可以使用终端中的命令连接到 mysqlmysql -udocker -p --portocol=tcp

更多细节

错误信息是Access denied for user 'docker'@'%%' (using password: YES),它said @'%%',我知道 '%' 是什么,但 '%%' 是什么意思?

标签: mysqldockermysql-workbenchnavicat

解决方案


请尝试使用主机mysql而不是连接容器中的 localhost。如果您在 Windows 上,请尝试192.168.99.100作为主机。

如果仍然有问题,请尝试使用mysql-compose.yml重新测试

version: "3.1"
services:

  mysql:
    image: mysql:5.7.22
    command: "--innodb_use_native_aio=0"
    restart: always
    environment:
      MYSQL_ROOT_PASSWORD: root
    env_file:
      - .env
    ports:
      - "3306:3306"
    volumes:
      - /var/database/docker/common:/var/lib/mysql
    networks:
      - mysqlnet
      - mysqlnetfpm

networks:
  mysqlnet:
    driver: bridge
  mysqlnetfpm:
    driver: bridge

注意:在运行新的 mysql 容器之前不要忘记删除旧的 mysqldata 文件。

现在您可以使用用户名 as root,密码 asroot并且对于内部容器(附加容器)使用主机作为 mysql。

如果您尝试从 docker 外部连接,请尝试使用 host as localhostor 127.0.0.1or your public docker ip


推荐阅读