用户不支持服务器请求的协议,考虑升级mysql用户 Docker 中创建 mysql 容器,并设置远程连接 报错

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;

 

 

转自:https://cloud.tencent.com/developer/article/1633614

 

posted @ 2020-08-31 20:03  傲娇的白狐  阅读(220)  评论(0)    收藏  举报