0. 背景
Docker 中创建 mysql 容器
1.创建MySQL容器
docker run -di --name mysql -p 33306:3306 -e MYSQL_ROOT_PASSWORD=123456 mysql
-p 代表端口映射,格式为 宿主机映射端口:容器运行端口 -e 代表添加环境变量 MYSQL_ROOT_PASSWORD是root用户的登陆密码
可能遇到的问题 这个时候使用客户端连接工具连接的话,会遇到: Client does not support authentication protocol 的错误。
解决办法是设置远程登录,让我们继续。
2. 设置远程登录
2.1 进入MySQL容器,登陆MySQL
docker exec -it mysql /bin/bash
2.2 登陆mysql**
mysql -u root -p
2.3 输入密码
这个时候会提示输入密码,输入即可。
2.4 进行授权远程连接授权
GRANT ALL ON *.* TO 'root'@'%';
刷新权限
flush privileges
注意,这时还不能远程访问 因为Navicat只支持旧版本的加密,需要更改mysql的加密规则
2.5 更改加密规则
ALTER USER 'root'@'localhost' IDENTIFIED BY 'password' PASSWORD EXPIRE NEVER;
更新root用户密码
ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY '123456';
刷新权限
flush privileges;
然后就可以使用 Navicat 连接数据库了。
© 版权声明
文章版权归作者所有,未经允许请勿转载。
THE END
喜欢就支持一下吧