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: localhost
、port: 5500
来连接mysql容器。
我刚刚完成了 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: localhost
、port: 5500
来连接mysql容器。