Docker MySQL 连接 DBeaver

Joh*_*ley 10 mysql dbconnection dbeaver docker docker-compose

我刚刚在 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
Run Code Online (Sandbox Code Playgroud)

数据库 Dockerfile:

FROM mysql:8.0
Run Code Online (Sandbox Code Playgroud)

索引.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!';
}
?>
Run Code Online (Sandbox Code Playgroud)

www Dockerfile:

FROM php:7.2-apache

RUN docker-php-ext-install mysqli
RUN docker-php-ext-enable mysqli
Run Code Online (Sandbox Code Playgroud)

这是 development.env 文件:

MYSQL_USER=sys_admin
MYSQL_PASSWORD=sys_password
MYSQL_ROOT_PASSWORD=root_password
Run Code Online (Sandbox Code Playgroud)

最后是 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
Run Code Online (Sandbox Code Playgroud)

现在我知道我要完全失明了……

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

在此处输入图片说明

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

在此处输入图片说明

我该如何解决这个问题?

viv*_*d4v 9

不要localhost_compliant-db在 dbeaver 中作为服务器主机提供,而是尝试提供它localhost

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

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

  • 我将服务器更新为 localhost,但现在我收到一个新的连接错误,内容如下:访问被拒绝用户 'root'@'172.10.2.1'(使用密码:YES) (2认同)

Ham*_*ade 9

一个非常干净的方式

1-docker compose up -d

2-docker ps

3-docker inspect <database container id> | grep -i IPAddress

4- 在 DBeaver 的服务器主机字段中输入 IP 值


Eng*_*ng7 7

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

首先,从容器所在的位置运行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
Run Code Online (Sandbox Code Playgroud)

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

[root@test-001 ~]# docker inspect 8c1d234a3731 | grep -i IPAddress
            "SecondaryIPAddresses": null,
            "IPAddress": "",
                    "IPAddress": "172.23.0.3",
Run Code Online (Sandbox Code Playgroud)

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

这应该工作


小智 5

如果可能的话,将驱动程序属性中的权限更改allowPublicKeyRetrievaltrue. 这对我有用。

AllowPublicKeyRetrieval=True

  • 就我而言,我得到了“不允许公钥检索”的信息,这完美地解决了问题! (2认同)