通过docker创建mysql容器

  1. docker run -d --name mysql -p 8123:3306 -e MYSQL_ROOT_PASSWORD=123456 mysql

-p 代表端口映射,格式为 宿主机映射端口:容器运行端口 -e 代表添加环境变量 MYSQL_ROOT_PASSWORD是root用户的登陆密码
可能遇到的问题 这个时候使用客户端连接工具连接的话,会遇到: Client does not support authentication protocol 的错误。
解决办法是设置远程登录,让我们继续。

设置远程登录

进入MySQL容器,登陆MySQL

  1. docker exec -it mysql /bin/bash

登陆mysql

  1. mysql -h1.123.35.36 -P8123 -u root -p

输入密码,登录

进行授权远程连接授权

  1. GRANT ALL ON *.* TO 'root'@'%';

刷新权限

  1. flush privileges

注意,这时还不能远程访问 因为Navicat只支持旧版本的加密,需要更改mysql的加密规则

更改加密规则

  1. ALTER USER 'root'@'localhost' IDENTIFIED BY 'password' PASSWORD EXPIRE NEVER;

更新root用户密码

  1. ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY '123456';

刷新权限

  1. flush privileges

然后就可以使用客户端进行远程登录