在 docker 中,连接 mysql 到外部数据库的方法如下:创建网络以连接容器。启动 mysql 容器并指定网络名称。授予外部访问权限以允许连接。使用连接字符串连接到外部数据库。

如何连接 Docker 中的 MySQL 到外部数据库
在 Docker 容器中运行 MySQL 时,可能需要连接到外部数据库以实现数据共享或访问外部数据源。以下是连接 Docker 中 MySQL 到外部数据库的方法:
1. 创建网络
Docker 容器默认处于不同的网络空间中,因此需要创建网络以便容器之间能够通信。可以使用以下命令创建网络:
<code>docker network create my-network</code>
2. 启动 MySQL 容器
连接到外部数据库之前,需要启动 MySQL 容器。以下命令将创建并启动 MySQL 容器,指定网络名称和暴露端口:
<code>docker run -d \
--name mysql \
--network my-network \
-p 3306:3306 \
mysql:5.7</code>3. 授予外部访问权限
默认情况下,MySQL 容器仅允许本地连接。需要授予外部访问权限以允许其他容器或主机连接。使用以下命令授予权限:
<code>docker exec mysql mysql -uroot -p <your-password></code>
在命令提示符下:
<code>GRANT ALL PRIVILEGES ON *.* TO 'username'@'%' IDENTIFIED BY 'password'; FLUSH PRIVILEGES;</code>
其中:
-
username是外部用户的名字 -
password是外部用户的密码 -
%允许来自任何主机的连接
4. 连接外部数据库
使用外部应用程序或工具来连接到外部数据库。可以使用以下连接字符串:
<code>mysql -h <external_host> -u <username> -p <password> <database_name></code>
其中:
-
<external_host></external_host>是外部数据库的主机名或 IP 地址 -
<username></username>是授予外部访问权限的用户名 -
<password></password>是授予外部访问权限的密码 -
<database_name></database_name>是要连接的数据库的名称










