MySQL8
2019-03-20
mysql
mysql5.7 —>mysql8 的升级
MySQL8的加密方式有变化
命令行查看MySQL8 账户的加密方式
在mysql8之前的版本使用的密码加密规则是mysql_native_password
,但是在mysql8则是caching_sha2_password
。
Navicat不支持 caching_sha2_password 这种加密方式,所以升级后 Navicat 不能连接 MySQL8
Navicat 连接 mysql8 的解决方案有三:
方案一 重新创建一个账号,设此账号的加密方式为 mysql_native_password,使用这个账号
create user ‘fanjinlong’@’%’ identified with mysql_native_password by ‘333’;
create user ‘your username’@’%’ identified with caching_sha2_password by ‘your password’;
ps. 此路不通,该账号无法创建 database 和 table
方案二 修改root 的密码加密方式,刷新
ALTER USER ‘root’@’localhost’ IDENTIFIED BY ‘password’ PASSWORD EXPIRE NEVER; # 更改root 的加密方式
ALTER USER ‘root’@’localhost’ IDENTIFIED WITH mysql_native_password BY ‘password’;# 重置密码
FLUSH PRIVILEGES; #刷新数据库
方案三 更换MySQL8 客户端
关于 caching_sha2_password
MySQL提供了两个身份验证插件,可以为用户帐户密码实现SHA-256哈希:
sha256_password:实现基本的SHA-256身份验证。
caching_sha2_password:实现SHA-256身份验证(如sha256_password),但在服务器端使用缓存以获得更好的性能,并具有更广泛的适用性的附加功能。
在MySQL 8.0中,caching_sha2_password是默认的身份验证插件而不是 mysql_native_password。
要使用通过caching_sha2_password插件进行身份验证的帐户连接到服务器,您必须使用安全连接或支持使用RSA密钥对进行密码交换的未加密连接,如本节后面所述。无论哪种方式, caching_sha2_password插件都使用MySQL的加密功能。