欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

MySQL報(bào)1045錯(cuò)誤的幾種可能場景

 更新時(shí)間:2024年02月04日 10:57:10   作者:bisal的個(gè)人雜貨鋪  
mysql數(shù)據(jù)庫中常常會(huì)遇見1045錯(cuò)誤,本文主要介紹了MySQL報(bào)1045錯(cuò)誤的幾種可能場景,具有一定的參考價(jià)值,感興趣的可以了解一下

在我們學(xué)習(xí) MySQL 或從事 MySQL DBA 工作期間,時(shí)常會(huì)遇到:“我嘗試連接到 MySQL 并且收到1045 錯(cuò)誤,但我確定我的用戶和密碼都沒問題”。

不管你現(xiàn)在是否是高手還是高高手,都不可避免曾經(jīng)在初學(xué)的時(shí)候犯過一些很初級(jí)的錯(cuò)誤,例如:用戶名密碼都填錯(cuò)了。而且工作一段時(shí)間后也偶爾會(huì)遇到一些不常見錯(cuò)誤原因。

一、連接錯(cuò)誤的主機(jī)

[root@localhost ~]# mysql -u root -p123456
mysql: [Warning] Using a password on the command line interface can be insecure.
ERROR 1045 (28000): Access denied for user 'root'@'localhost' (using password: YES)

如果未指定要連接的主機(jī)(使用 -h 標(biāo)志),則 MySQL 客戶端將嘗試連接到 localhost 實(shí)例,同時(shí)您可能嘗試連接到另一個(gè)主機(jī)端口實(shí)例。

修復(fù):仔細(xì)檢查您是否嘗試連接到 localhost,或者確保指定主機(jī)和端口(如果它不是 localhost):

[root@localhost ~]# mysql -u root -p123456 -h <IP> -P 3306

二、用戶不存在

[root@localhost ~]# mysql -u nonexistant -p123456 -h localhost
mysql: [Warning] Using a password on the command line interface can be insecure.
ERROR 1045 (28000): Access denied for user 'nonexistant'@'localhost' (using password: YES)

修復(fù):仔細(xì)檢查用戶是否存在:

mysql> SELECT User FROM mysql.user WHERE User='nonexistant';
Empty set (0.00 sec)

如果用戶不存在,請(qǐng)創(chuàng)建一個(gè)新用戶:

mysql> CREATE USER 'nonexistant'@'localhost' IDENTIFIED BY 'sekret';
Query OK, 0 rows affected (0.00 sec)
mysql> FLUSH PRIVILEGES;
Query OK, 0 rows affected (0.01 sec)

三、用戶存在但客戶端主機(jī)無權(quán)連接

[root@localhost ~]# mysql -u nonexistant -p123456
mysql: [Warning] Using a password on the command line interface can be insecure.
ERROR 1045 (28000): Access denied for user 'nonexistant'@'localhost' (using password: YES)

修復(fù):您可以通過以下查詢檢查 MySQL 允許連接的主機(jī)用戶/主機(jī):

mysql> SELECT Host, User FROM mysql.user WHERE User='nonexistant';
+-------------+-------------+
| Host        | User        |
+-------------+-------------+
| 192.168.0.1 | nonexistant |
+-------------+-------------+
1 row in set (0.00 sec)

如果需要檢查客戶端連接的 IP,可以使用以下 Linux 命令來獲取服務(wù)器 IP:

[root@localhost ~]# ip address | grep inet | grep -v inet6
    inet 127.0.0.1/8 scope host lo
    inet 192.168.0.20/24 brd 192.168.0.255 scope global dynamic wlp58s0

或公共IP:

[root@localhost ~]# dig +short myip.opendns.com @resolver1.opendns.com
177.128.214.181

然后,您可以創(chuàng)建具有正確主機(jī)(客戶端 IP)的用戶,或使用'%'(通配符)來匹配任何可能的 IP:

mysql> CREATE USER 'nonexistant'@'%' IDENTIFIED BY '123456';
Query OK, 0 rows affected (0.00 sec)

四、密碼錯(cuò)誤,或者用戶忘記密碼

mysql> CREATE USER 'nonexistant'@'%' IDENTIFIED BY '123456';
Query OK, 0 rows affected (0.00 sec)

修復(fù):檢查和/或重置密碼:

您無法從 MySQL 以純文本格式讀取用戶密碼,因?yàn)槊艽a哈希用于身份驗(yàn)證,但您可以將哈希字符串與“PASSWORD”函數(shù)進(jìn)行比較:

mysql> SELECT Host, User, authentication_string, PASSWORD('forgotten') FROM mysql.user WHERE User='nonexistant';
+-------------+-------------+-------------------------------------------+-------------------------------------------+
| Host        | User        | authentication_string                     | PASSWORD('forgotten')                     |
+-------------+-------------+-------------------------------------------+-------------------------------------------+
| 192.168.0.1 | nonexistant | *AF9E01EA8519CE58E3739F4034EFD3D6B4CA6324 | *70F9DD10B4688C7F12E8ED6C26C6ABBD9D9C7A41 |
| %           | nonexistant | *AF9E01EA8519CE58E3739F4034EFD3D6B4CA6324 | *70F9DD10B4688C7F12E8ED6C26C6ABBD9D9C7A41 |
+-------------+-------------+-------------------------------------------+-------------------------------------------+
2 rows in set, 1 warning (0.00 sec)

我們可以看到 PASSWORD('forgotten')哈希與 authentication_string 列不匹配,這意味著 password string ='forgotten' 不是正確的登錄密碼。

如果您需要覆蓋密碼,可以執(zhí)行以下查詢:

mysql> set password for 'nonexistant'@'%' = 'hello$!world';
Empty set (0.00 sec)

五、Bash 轉(zhuǎn)換密碼中的特殊字符

[root@localhost ~]# mysql -u nonexistant -phello$!world
mysql: [Warning] Using a password on the command line interface can be insecure.
ERROR 1045 (28000): Access denied for user 'nonexistant'@'localhost' (using password: YES)

修復(fù):通過在單引號(hào)中包裝密碼來防止 bash 解釋特殊字符:

[root@localhost ~]# mysql -u nonexistant -p'hello$!world'
mysql: [Warning] Using a password on the command line interface can be insecure
...
mysql>

六、SSL 是必須的,但客戶沒有使用

mysql> create user 'ssluser'@'%' identified by '123456';
Query OK, 0 rows affected (0.00 sec)
mysql> alter user 'ssluser'@'%' require ssl;
Query OK, 0 rows affected (0.00 sec)
...
[root@localhost ~]# mysql -u ssluser -p123456
mysql: [Warning] Using a password on the command line interface can be insecure.
ERROR 1045 (28000): Access denied for user 'ssluser'@'localhost' (using password: YES)

修復(fù):添加 -ssl-mode 標(biāo)志(-ssl 標(biāo)志已棄用但也可以使用)

[https://dev.mysql.com/doc/relnotes/mysql/5.7/en/news-5-7-11.html]
[root@localhost ~]# mysql -u ssluser -p123456 --ssl-mode=REQUIRED
...
mysql>

如果真的被鎖定并需要繞過身份驗(yàn)證機(jī)制以重新獲得對(duì)數(shù)據(jù)庫的訪問權(quán)限,請(qǐng)執(zhí)行以下幾個(gè)簡單步驟,

  • 停止實(shí)例
  • 編輯 my.cnf 并在 [mysqld] 下添加 skip-grant-tables(這樣可以在不提示輸入密碼的情況下訪問 MySQL)。在 MySQL 8.0 上,跳過網(wǎng)絡(luò)是自動(dòng)啟用的(只允許從 localhost 訪問 MySQL),但對(duì)于以前的 MySQL 版本,建議在 [mysqld] 下添加 -skip-networking
  • 啟動(dòng)實(shí)例
  • 使用 root 用戶訪問(mysql -uroot -hlocalhost);
  • 發(fā)出必要的 GRANT / CREATE USER / SET PASSWORD 以糾正問題(可能設(shè)置一個(gè)已知的 root 密碼將是正確的事情:SET PASSWORD FOR 'root'@'localhost'='S0vrySekr3t'
  • 停止實(shí)例
  • 編輯 my.cnf 并刪除 skip-grant-tables 和 skip-networking
  • 再次啟動(dòng) MySQL
  • 您應(yīng)該能夠使用 roothost 從 root 用戶登錄,并對(duì) root 用戶執(zhí)行任何其他必要的糾正操作。

到此這篇關(guān)于MySQL報(bào)1045錯(cuò)誤的幾種可能場景的文章就介紹到這了,更多相關(guān)MySQL報(bào)1045錯(cuò)誤內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • MySQL中CURRENT_TIMESTAMP時(shí)間戳的使用詳解

    MySQL中CURRENT_TIMESTAMP時(shí)間戳的使用詳解

    這篇文章主要給大家介紹了關(guān)于MySQL中CURRENT_TIMESTAMP時(shí)間戳的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2022-03-03
  • MySQL雙主配置的項(xiàng)目實(shí)踐

    MySQL雙主配置的項(xiàng)目實(shí)踐

    本文詳細(xì)介紹了配置兩臺(tái)MySQL服務(wù)器之間的主從復(fù)制,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2024-12-12
  • Navicat For MySQL的簡單使用教程

    Navicat For MySQL的簡單使用教程

    這篇文章主要介紹了Navicat For MySQL的簡單使用教程,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià),需要的朋友可以參考下
    2019-06-06
  • Windows10下mysql 8.0.22 安裝配置方法圖文教程

    Windows10下mysql 8.0.22 安裝配置方法圖文教程

    這篇文章主要為大家詳細(xì)介紹了Windows10下mysql 8.0.22 安裝配置方法圖文教程,文中安裝步驟介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-11-11
  • Canal監(jiān)聽MySQL的實(shí)現(xiàn)步驟

    Canal監(jiān)聽MySQL的實(shí)現(xiàn)步驟

    本文主要介紹了Canal監(jiān)聽MySQL的實(shí)現(xiàn)步驟,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-08-08
  • Windows11下MySQL?8.0.29?安裝配置方法圖文教程

    Windows11下MySQL?8.0.29?安裝配置方法圖文教程

    這篇文章主要為大家詳細(xì)介紹了Windows11下MySQL?8.0.29?安裝配置方法圖文教程,文中安裝步驟介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-07-07
  • MySQL中聚簇索引與非聚簇索引的實(shí)現(xiàn)

    MySQL中聚簇索引與非聚簇索引的實(shí)現(xiàn)

    MySQL數(shù)據(jù)庫中,聚簇索引和非聚簇索引是提高查詢效率的關(guān)鍵,聚簇索引決定數(shù)據(jù)的物理存儲(chǔ)順序,通常由主鍵或UNIQUE索引構(gòu)成,非聚簇索引則通過指針定位數(shù)據(jù)行,適合訪問數(shù)據(jù)子集,下面就來具體介紹一下,感興趣的可以了解一下
    2024-09-09
  • MySQL多版本并發(fā)控制mvcc原理淺析

    MySQL多版本并發(fā)控制mvcc原理淺析

    mvcc多版本并發(fā)控制是一種數(shù)據(jù)庫的并發(fā)控制機(jī)制,本文主要介紹了MySQL多版本并發(fā)控制mvcc原理淺析,具有一定的參考價(jià)值,感興趣的可以了解一下
    2024-07-07
  • mysql8如何設(shè)置不區(qū)分大小寫ubuntu20

    mysql8如何設(shè)置不區(qū)分大小寫ubuntu20

    這篇文章主要介紹了mysql8如何設(shè)置不區(qū)分大小寫ubuntu20問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-05-05
  • SQL中日期與字符串互相轉(zhuǎn)換操作實(shí)例

    SQL中日期與字符串互相轉(zhuǎn)換操作實(shí)例

    我們經(jīng)常出于某種目的需要使用各種各樣的日期格式,當(dāng)然我們可以使用字符串操作來構(gòu)造各種日期格式,下面這篇文章主要給大家介紹了關(guān)于SQL中日期與字符串互相轉(zhuǎn)換操作的相關(guān)資料,需要的朋友可以參考下
    2022-10-10

最新評(píng)論