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 中,我正在尝试建立连接:
但是当我测试连接时,我得到以下响应:
我该如何解决这个问题?
不要localhost_compliant-db在 dbeaver 中作为服务器主机提供,而是尝试提供它localhost。
3306端口也绑定在主机上,因此localhost:3306从您的主机应该可以工作。
PS - 我假设 dbeaver 和 docker compose stack 都在同一台机器上。如果没有,您需要映射localhost_compliant-db到您的主机可以理解的某些IP。
一个非常干净的方式
1-docker compose up -d
2-docker ps
3-docker inspect <database container id> | grep -i IPAddress
4- 在 DBeaver 的服务器主机字段中输入 IP 值
对于那些在不同机器上运行数据库的人,您可以执行以下操作:
首先,从容器所在的位置运行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
如果可能的话,将驱动程序属性中的权限更改allowPublicKeyRetrieval为true. 这对我有用。
AllowPublicKeyRetrieval=True
| 归档时间: |
|
| 查看次数: |
18785 次 |
| 最近记录: |