SQLyog連接MySQL8.0+報(bào)錯(cuò):錯(cuò)誤號(hào)碼2058的解決方案
本文將總結(jié)如何解決 SQLyog 連接 MySQL8.0+ 時(shí)報(bào)錯(cuò):錯(cuò)誤號(hào)碼2058
一、問(wèn)題現(xiàn)象
使用SQLyog連接MySQL8.0+數(shù)據(jù)庫(kù)時(shí),報(bào)錯(cuò):錯(cuò)誤號(hào)碼2058 Plugin caching_sha2_password could not be loaded
二、原因分析
出現(xiàn)這個(gè)問(wèn)題,是因?yàn)?MySQL 從 8.0 版本開(kāi)始,新增了caching_sha2_password
授權(quán)插件,并且新建用戶時(shí)默認(rèn)使用該插件進(jìn)行加密,而你的 SQLyog 版本無(wú)法識(shí)別該加密方式加密的密碼。
(多數(shù)情況下是你的SQLyog版本過(guò)時(shí)了,新的SQLyog已支持識(shí)別caching_sha2_password
加密方式的密碼)
MySQL :: MySQL 8.0 Reference Manual :: 5.1.8 Server System Variables
三、解決方案
1. 方案1:更新SQLyog版本
查看你的SQLyog安裝路徑下,是否有caching_sha2_password.dll
動(dòng)態(tài)庫(kù),如果沒(méi)有則說(shuō)明你的SQLyog版本,不支持通過(guò)caching_sha2_password
加密的用戶進(jìn)行連接數(shù)據(jù)庫(kù)。
查看了一下SQLyog的發(fā)布?xì)v史:Version History - 2019 - SQLyog Knowledge Base (webyog.com)
從SQLyog 13.1.3
開(kāi)始,才支持caching_sha2_password
授權(quán)插件
如果你需要更新SQLyog,你可能需要 SQLyog 各版本下載與安裝
2. 方案2:修改用戶的授權(quán)插件
使用有mysql.user
表權(quán)限的用戶連接mysql并執(zhí)行如下命令:
mysql> ALTER USER 'sqlyog'@'localhost' IDENTIFIED WITH mysql_native_password BY '1234qwer'; Query OK, 0 rows affected (0.03 sec) mysql> FLUSH PRIVILEGES; Query OK, 0 rows affected (0.03 sec) mysql> SELECT user,host,plugin FROM mysql.user; +------------------+-----------+-----------------------+ | user | host | plugin | +------------------+-----------+-----------------------+ | mysql.infoschema | localhost | caching_sha2_password | | mysql.session | localhost | caching_sha2_password | | mysql.sys | localhost | caching_sha2_password | | root | localhost | caching_sha2_password | | sqlyog | localhost | mysql_native_password | +------------------+-----------+-----------------------+ 5 rows in set (0.00 sec)
解釋:ALTER USER 'sqlyog'@'localhost' IDENTIFIED WITH mysql_native_password BY '1234qwer'
,使用mysql_native_password
授權(quán)插件更新用戶密碼,sqlyog@localhost
換為替換為你自己的user及host
3. 方案3:修復(fù)my.cnf 或 my.ini配置文件
查找配置文件(如果你的mysql是安裝在Window下):
C:\Users\Administrator>mysql --help | findstr "my.ini" C:\WINDOWS\my.ini C:\WINDOWS\my.cnf C:\my.ini C:\my.cnf D:\Chen\MySoft\mysql-8.1.0-winx64\my.ini D:\Chen\MySoft\mysql-8.1.0-winx64\my.cnf
查找配置文件(如果你的mysql是安裝在Linux或docker里):
sh-4.4# mysql --help | grep 'my.cnf' order of preference, my.cnf, $MYSQL_TCP_PORT, /etc/my.cnf /etc/mysql/my.cnf /usr/etc/my.cnf ~/.my.cnf
按順序找配置文件,找到后打開(kāi)配置文件,在配置文件的[mysqld]
下添加如下配置:
default-authentication-plugin=mysql_native_password
然后重啟mysql服務(wù)
Windows 上重啟服務(wù)
net stop mysqlnet start mysql
Linux 上重啟服務(wù)
systemctl stop mysqld systemctl start mysqld
Docker 上重啟mysql容器
docker restart mysql81
mysql81
使用你的 mysql容器名稱或ID替換
重啟完成后,mysql服務(wù)使用的默認(rèn)加密授權(quán)插件就成了mysql_native_password
,然后新創(chuàng)建的用戶如果不指定授權(quán)插件,那么創(chuàng)建完成后就使用默認(rèn)插件加密了。
mysql> show variables like 'default_authentication_plugin'; +-------------------------------+-----------------------+ | Variable_name | Value | +-------------------------------+-----------------------+ | default_authentication_plugin | mysql_native_password | +-------------------------------+-----------------------+ 1 row in set (0.01 sec) mysql> CREATE USER 'sqlyog'@'%' IDENTIFIED BY '1234qwer'; Query OK, 0 rows affected (0.04 sec) mysql> GRANT ALL PRIVILEGES ON *.* TO 'sqlyog'@'%'; Query OK, 0 rows affected (0.02 sec) mysql> FLUSH PRIVILEGES; Query OK, 0 rows affected (0.01 sec) mysql> SELECT user,host,plugin FROM mysql.user; +------------------+-----------+-----------------------+ | user | host | plugin | +------------------+-----------+-----------------------+ | root | % | caching_sha2_password | | sqlyog | % | mysql_native_password | | mysql.infoschema | localhost | caching_sha2_password | | mysql.session | localhost | caching_sha2_password | | mysql.sys | localhost | caching_sha2_password | | root | localhost | caching_sha2_password | +------------------+-----------+-----------------------+ 6 rows in set (0.00 sec)
此時(shí)再使用新創(chuàng)建的用戶,就可以連接mysql8.0+的數(shù)據(jù)庫(kù)了。
注意:對(duì)于已有的用戶,如果使用的仍是caching_sha2_password
加密方式,那么仍無(wú)法用SQLyog連接,你可以使用方案2,重新設(shè)置其加密方式及密碼。
四、最后總結(jié)
- 嚴(yán)格來(lái)說(shuō)上述
方案3
、方案2
是一樣的(不太推薦方案3)。方案3
僅是將服務(wù)器默認(rèn)的授權(quán)插件改為了mysql_native_password
,它僅對(duì)新創(chuàng)建的用戶起作用(前提是創(chuàng)建用戶時(shí)沒(méi)有指定授權(quán)插件),并不會(huì)影響已有的用戶的加密方式。如果想使用已有用戶連接mysql,需使用方案2
重新設(shè)置其授權(quán)插件及密碼。 方案1
更新SQLyog的方案還是值得嘗試的,畢竟是一勞永逸的事兒。更新SQLyog 13.1.3+
后,無(wú)論連接用戶使用什么授權(quán)插件,都可連接上。
以上就是SQLyog連接MySQL8.0+報(bào)錯(cuò):錯(cuò)誤號(hào)碼2058的解決方案的詳細(xì)內(nèi)容,更多關(guān)于SQLyog連接MySQL8.0+報(bào)錯(cuò)的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
- SQLyog連接MySQL8.0+報(bào)錯(cuò):錯(cuò)誤碼2058的解決方案
- SQLyog連接MySQL8.0報(bào)2058錯(cuò)誤的完美解決方法
- Navicat連接MySQL出現(xiàn)2059錯(cuò)誤的解決方案
- Navicat 連接MySQL8.0.11出現(xiàn)2059錯(cuò)誤
- mysql安裝navicat之后,出現(xiàn)2059,Authentication plugin及本地鏈接虛擬機(jī)docker,遠(yuǎn)程鏈接服務(wù)器
- navicat連接mysql出現(xiàn)2059錯(cuò)誤的解決方法
- MySQL錯(cuò)誤代碼2058和2059的解決辦法
相關(guān)文章
MySQL時(shí)間盲注的五種延時(shí)方法實(shí)現(xiàn)
MySQL時(shí)間盲注主要有五種,sleep(),benchmark(t,exp),笛卡爾積,GET_LOCK() RLIKE正則,本文就主要介紹了這五種方法,感興趣的可以了解一下2021-05-05sql語(yǔ)句中l(wèi)ike的用法詳細(xì)解析
以下是對(duì)sql語(yǔ)句中l(wèi)ike的用法進(jìn)行了詳細(xì)的分析介紹,需要的朋友可以過(guò)來(lái)參考下2013-08-08MySQL更改數(shù)據(jù)字段的前幾位數(shù)字的方法示例
本文主要介紹了MySQL更改數(shù)據(jù)字段的前幾位數(shù)字的方法示例,包括使用SUBSTRING函數(shù)、REPLACE函數(shù)、LEFT函數(shù),還是正則表達(dá)式或者CASE語(yǔ)句,具有一定的參考價(jià)值,感興趣的可以了解一下2024-08-08深入淺析MySQL 中 Identifier Case Sensitivity問(wèn)題
這篇文章主要介紹了MySQL 中 Identifier Case Sensitivity,需要的朋友可以參考下2018-09-09關(guān)于mysql的時(shí)區(qū)問(wèn)題
這篇文章主要介紹了關(guān)于mysql的時(shí)區(qū)問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家,2023-11-11Kettle的MySQL數(shù)據(jù)源版本問(wèn)題及解決
這篇文章主要介紹了Kettle的MySQL數(shù)據(jù)源版本問(wèn)題及解決,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-10-10