Docker MySQL 连接DBeaver

Docker MySQL connection DBeaver

我刚刚完成了 youtube 上的这个 Docker 教程:

https://www.youtube.com/watch?v=SXY0MLHP3hA&lc=Ugzp3vKtSOp0rn2lYyd4AaABAg

我能够为 PHP 和 MySQL 创建几个 Docker 容器。文件结构如下:

>Docker_PHP_MySQL
 >DB
   -Dockerfile
 >src
   -index.php
 >www
   -Dockerfile
 development.env
 docker-compose.yml

数据库Docker文件:

FROM mysql:8.0

index.php:

<?php
$mysqli = new mysqli('tut07-db', getenv('MYSQL_USER'), getenv('MYSQL_PASSWORD'), 'information_schema');
if($mysqli->connect_error) 
{
  echo 'Connection Error [', $mysqli->connect_errno, ']: ', $mysqli->connect_error;
} 
else 
{
  echo 'MySQLi Connected Successfully!';
}
?>

www Docker文件:

FROM php:7.2-apache

RUN docker-php-ext-install mysqli
RUN docker-php-ext-enable mysqli

这是 development.env 文件:

MYSQL_USER=sys_admin
MYSQL_PASSWORD=sys_password
MYSQL_ROOT_PASSWORD=root_password

最后,docker-compose.yml 文件:

version: "3"

networks:
  tut07-frontend:
    driver: bridge
    ipam:
      driver: default
      config:
        - subnet: 172.10.1.0/24
  tut07-backend:
    driver: bridge
    ipam: 
      driver: default
      config:
        - subnet: 172.10.2.0/23

services:
  tut07-db:
    build: ./db
    command: --default-authentication-plugin=mysql_native_password
    ports:
      - 3306:3306
    networks:
      tut07-backend:
        ipv4_address: 172.10.3.2
    env_file:
      - ./development.env
  tut07-www:
    build: ./www
    ports:
      - 8080:80
    volumes:
      - ./src:/var/www/html/
    networks:
      tut07-backend:
        ipv4_address: 172.10.2.2
      tut07-frontend:
        ipv4_address: 172.10.1.2
    depends_on:
      - tut07-db
    env_file:
      - ./development.env

现在这是我知道我要完全失明的地方...

在 dbeaver 中,我正在尝试建立连接:

但是当我测试连接时,我得到以下响应:

我该如何解决这个问题?

不要将 localhost_compliant-db 作为 dbeaver 中的服务器主机,而是尝试将其设为 localhost

3306 端口也在主机上绑定,因此主机上的 localhost:3306 应该可以工作。

PS - 我假设 dbeaver 和 docker compose stack 都在同一台机器上。如果不是,您需要将 localhost_compliant-db 映射到您的主机可以理解的特定 IP。

在我的例子中,我使用 DBBeaver 连接到端口 3306 上的 MariaDB,但是我的容器端口没有映射到我的本地 3306 端口,所以我只需要将端口配置添加到 docker-compose.yml

ports:
- "3306:3306"

对于那些运行宁DB在不同机器上的人,您可以执行以下操作:

首先,从容器所在的位置,运行 docker ps 获取容器详细信息,包括 Container ID

[root@test-001 ~]# docker ps 
CONTAINER ID        IMAGE                    COMMAND                  CREATED             STATUS              PORTS                    NAMES
1b02333fb3b9        tutum/nginx              "/usr/sbin/nginx"        6 weeks ago         Up 7 days           0.0.0.0:80->80/tcp       docker_nginx_1
8c1d234a3731        mariadb                  "docker-entrypoint.s…"   6 weeks ago         Up 7 days           0.0.0.0:3306->3306/tcp   docker_mysql_1

获取数据库容器的ID后,运行 docker inspect CONTAINER_ID获取该容器的相关IP地址。

[root@test-001 ~]# docker inspect 8c1d234a3731 | grep -i IPAddress
            "SecondaryIPAddresses": null,
            "IPAddress": "",
                    "IPAddress": "172.23.0.3",

在 Dbeaver 上,在添加新连接时选择数据库类型后 window,转到 network settings (SSH, ...) 然后输入您的 docker 机器详细信息。从主页上,在 Server Host: 添加您从 docker inspect 命令获得的 IP,然后添加您的凭据。

这应该有效

如果可能,请将驱动程序属性 allowPublicKeyRetrieval 中的权限更改为 true。这对我有用。

AllowPublicKeyRetrieval=True

以我为例,因为我有不同的 mysql 个容器,我需要为每个 mysql 个容器设置不同的端口映射。

例如, 我将下面的端口设置用于 docker-compose.yml.

中的 mysql 个容器之一
ports:
- "5500:3306"

所以,我需要在DBeaver中设置host: localhostport: 5500来连接mysql容器。