【出现1251错误】远程连接docker容器中的mysql8.0数据库时出现连接不上
远程连接docker容器中的mysql8.0数据库时出现连接不上,mysql8.0版本之前没有该问题.),因此报上面的错,所以我们将mysql用户使用的。,并且给它远程访问权限,完成后这个用户也可以访问.添加用户,同时设置登陆加密方式为。中找不到新的身份验证插件(不同,导致错误产生。
【出现1251错误】远程连接docker容器中的mysql8.0数据库时出现连接不上
🔔报错信息
1251 - Client does not support authentication protocol requested by server; consider upgrading MySQL client
👀场景:
远程连接docker容器中的mysql8.0数据库时出现连接不上,mysql8.0版本之前没有该问题.
👀原因分析:
出现1251的主要原因是由于mysql版本的问题,mysql8.0
版本,与mysql8.0
以下版本的加密方式不同,导致错误产生。
- MySql 8.0.11 换了新的身份验证插件(
caching_sha2_password
), - 而原来的身份验证插件为(
mysql_native_password
)。
而客户端工具Navicat Premium12
中找不到新的身份验证插件(caching_sha2_password
),因此报上面的错,所以我们将mysql用户使用的 登录密码加密规则还原成 mysql_native_password
,即可登陆成功。
🚀 解决:
方法一:修改root加密方式
对于这种方式,它的适用场景是当你已经通过mysql8镜像创建了容器,那么这个时候你需要进入容器的mysql,切换mysq数据库再更改加密方式。
1) 查看root或其他用户信息的加密方式
[root@centos7 ~]# mysql -u root -p #登陆mysql
mysql> use mysql; # 切换mysql数据库
mysql> select user,plugin from user where user='root'; #查看root的加密方式
2) 改变加密方式
alter user 'root'@'%' identified with mysql_native_password by '123456';
mysql> select user,plugin from user where user='root';
通过上面两步,即可解决问题
方法二:在容器启动时配置加密方式为mysql_native_password
方法二的适用场景是当你还没有通过mysql8镜像创建容器,这个时候你可以在通过mysql8镜像启动容器的时候配置mysql的加密方式,如下解决。
# 创建容器并启动
docker run -id \
-p 3306:3306 \
--name=mysql8 \
-v /root/mysql8/conf:/etc/mysql/conf.d \
-v /root/mysql8/logs:/logs \
-v /root/mysql8/data:/var/lib/mysql \
-e MYSQL_ROOT_PASSWORD=root \
-e identified=mysql_native_password \
mysql:8.0
重点是该行代码-e identified=mysql_native_password
,配置了加密方式。
方法三:添加新用户并设置加密方式为mysql_native_password``mysql_native_password
添加用户,同时设置登陆加密方式为
mysql_native_password
,并且给它远程访问权限,完成后这个用户也可以访问.
添加远程登录用户
CREATE USER 'mjh'@'%' IDENTIFIED WITH mysql_native_password BY '123456';
GRANT ALL PRIVILEGES ON *.* TO 'mjh'@'%';
🐯总结:
出现此类连接不上问题,主要是因为mysql8.0
版本,与mysql8.0
以下版本的加密方式不同,而客户端工具Navicat Premium12
中找不到mysql8.0
新的身份验证插件(caching_sha2_password
)导致错误产生。解决办法如上三种,我比较推荐第二种。
我认为出现该问题本质是Navicat Premium12
中找不到mysql8.0
新的身份验证插件导致的,那么我相信在未来这个小瑕疵能够被解决的。
更多推荐
所有评论(0)