当前位置: 代码网 > 服务器>服务器>云虚拟主机 > Docker Desktop中安装MySQL并开启远程访问的详细教程

Docker Desktop中安装MySQL并开启远程访问的详细教程

2025年02月13日 云虚拟主机 我要评论
一、安装 mysql 容器拉取 mysql 镜像:docker pull mysql:latest这将从 docker hub 上拉取最新版本的 mysql 镜像。如果你想使用特定版本的 mysql,

一、安装 mysql 容器

拉取 mysql 镜像:

docker pull mysql:latest

这将从 docker hub 上拉取最新版本的 mysql 镜像。如果你想使用特定版本的 mysql,可以将 latest 替换为具体的版本号,例如 mysql:8.0。
运行 mysql 容器:

docker run -d --name mysql-container -e mysql_root_password=your_password -p 3303:3306 mysql:latest

docker run -d:表示在后台运行容器。
–name mysql-container:为容器命名为 mysql-container,你可以使用自己喜欢的名称。
-e mysql_root_password=your_password:设置 mysql 的 root 用户密码,将 your_password 替换为你想要设置的密码。
-p 3303:3306:将容器内的 3306 端口映射到主机的 3303 端口,这样你就可以通过主机的 3303 端口访问容器内的 mysql 服务。

二、配置 mysql 允许远程访问

进入 mysql 容器:

docker exec -it mysql-container bash

这将进入到 mysql-container 容器的命令行界面。
登录 mysql 服务:

mysql -uroot -p

输入之前设置的 your_password 登录 mysql。
修改 mysql 配置允许远程访问:
sql

use mysql;

– 创建允许远程访问的用户或修改 root 用户允许远程访问

create user 'your_user'@'%' identified by 'your_password';

– 授予用户权限

grant all privileges on *.* to 'your_user'@'%' with grant option;

– 刷新权限

flush privileges;

将 your_user 和 your_password 替换为你想要设置的用户名和密码。
create user ‘your_user’@‘%’ identified by ‘your_password’;:创建一个可以从任何 ip 地址访问的用户。如果你想只允许从特定 ip 地址访问,可以将 % 替换为相应的 ip 地址,例如 ‘your_user’@‘192.168.1.100’。
grant all privileges on . to ‘your_user’@‘%’ with grant option;:授予用户在所有数据库和表上的所有权限,并允许该用户授予其他用户权限。

注1:

查看当前用户及其权限:

sql

select user, host from mysql.user;

注2:
检查主机上的 mysql 服务占用情况
使用命令行检查:
cmd

netstat -ano | findstr :3306

这将显示使用 3306 端口的进程的 pid(进程标识符)。
如果你看到有进程正在使用 3306 端口,你可以根据 pid 在任务管理器中查看具体的进程信息。在任务管理器中,点击 “详细信息” 选项卡,找到相应的 pid,确认是否是主机上的 mysql 服务。

这会列出所有 mysql 用户及其允许的连接来源(host)。

检查 root 用户是否允许远程连接:

如果 host 为 %,表示允许从任何主机连接。

如果 host 为 localhost,表示只允许本地连接。

三、配置防火墙和网络

确保主机防火墙允许 3306 端口访问:

  • 在 windows 上,你可以打开 windows 防火墙高级设置,创建一个新的入站规则,允许 tcp 端口 3306 的访问。
  • 在 macos 上,打开系统偏好设置 -> 安全与隐私 -> 防火墙,确保允许 mysql 服务的访问。

检查 docker 网络设置:

  • 确保 docker desktop 的网络设置正常,一般默认设置下应该可以正常工作。如果有问题,可以尝试重启 docker desktop 或检查网络模式,通常使用默认的 bridge 模式即可。

四、测试远程连接

使用 mysql 客户端连接:
在你的电脑上,使用 mysql 客户端工具(如 mysql workbench、navicat 或命令行)进行连接。
连接参数如下:
主机:你的 docker 主机的 ip 地址(如果你在本地测试,可以使用 127.0.0.1 或 localhost)。
端口:3303。
用户:你创建的 your_user 或 root。
密码:你设置的 your_password。
注意事项
安全考虑:
开启远程访问会带来一定的安全风险,建议设置强密码,并仅允许必要的 ip 地址访问,避免使用 % 允许所有 ip 访问,除非你确实需要从任何地方访问。
数据持久化:
上述方法将 mysql 数据存储在容器内,容器删除后数据会丢失。如果需要持久化数据,可以使用 docker 卷,在运行容器时添加 -v /host/path:/var/lib/mysql 参数,将容器内的 /var/lib/mysql 目录映射到主机的 /host/path 目录,例如:

docker run -d --name mysql-container -e mysql_root_password=your_password -p 3306:3306 -v /my/host/directory:/var/lib/mysql mysql:latest

通过上述步骤,你应该可以在 docker desktop 中成功安装 mysql 并开启远程访问,使你的电脑能够连接到该 mysql 服务。记得在操作过程中,根据你的具体需求和实际情况调整相关参数和设置,同时注意安全和数据的保存问题。

到此这篇关于docker desktop中安装mysql并开启远程访问的详细教程的文章就介绍到这了,更多相关docker desktop mysql远程访问内容请搜索代码网以前的文章或继续浏览下面的相关文章希望大家以后多多支持代码网!

(0)

相关文章:

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论

验证码:
Copyright © 2017-2025  代码网 保留所有权利. 粤ICP备2024248653号
站长QQ:2386932994 | 联系邮箱:2386932994@qq.com