濮阳杆衣贸易有限公司

主頁 > 知識庫 > MySQL root密碼忘記后更優(yōu)雅的解決方法

MySQL root密碼忘記后更優(yōu)雅的解決方法

熱門標(biāo)簽:承德電腦地圖標(biāo)注 地圖標(biāo)注賺錢真假 陜西400電話如何申請 合肥營銷外呼系統(tǒng)收費(fèi) 商家地圖標(biāo)注哪個好 遵義地圖標(biāo)注app 深圳 德惠市地圖標(biāo)注 外呼系統(tǒng)從哪買

前言

一直以來,對于MySQL root密碼的忘記,以為只有一種解法-skip-grant-tables。

問了下群里的大咖,第一反應(yīng)也是skip-grant-tables。通過搜索引擎簡單搜索了下,無論是百度,抑或Google,只要是用中文搜索,首頁都是這種解法??梢娺@種解法在某種程度上已經(jīng)占據(jù)了使用者的心智。下面具體來看看。

skip-grant-tables的解法

首先,關(guān)閉實(shí)例

這里,只能通過kill mysqld進(jìn)程的方式。

注意:不是mysqld_safe進(jìn)程,也切忌使用kill -9。

# ps -ef |grep mysqld
root  6220 6171 0 08:14 pts/0 00:00:00 /bin/sh bin/mysqld_safe --defaults-file=my.cnf
mysql  6347 6220 0 08:14 pts/0 00:00:01 /usr/local/mysql57/bin/mysqld --defaults-file=my.cnf --basedir=/usr/local/mysql57 --datadir=/usr/local/mysql57/data --plugin-dir=/usr/local/mysql57/lib/plugin --user=mysql --log-error=slowtech.err --pid-file=slowtech.pid --socket=/usr/local/mysql57/data/mysql.sock --port=3307
root  6418 6171 0 08:17 pts/0 00:00:00 grep --color=auto mysqld

# kill 6347

使用--skip-grant-tables參數(shù),重啟實(shí)例

# bin/mysqld_safe --defaults-file=my.cnf --skip-grant-tables --skip-networking 

設(shè)置了該參數(shù),則實(shí)例在啟動過程中會跳過權(quán)限表的加載,這就意味著任何用戶都能登錄進(jìn)來,并進(jìn)行任何操作,相當(dāng)不安全。

建議同時添加--skip-networking參數(shù)。其會讓實(shí)例關(guān)閉監(jiān)聽端口,自然也就無法建立TCP連接,而只能通過本地socket進(jìn)行連接。

MySQL8.0就是這么做的,在設(shè)置了--skip-grant-tables參數(shù)的同時會自動開啟--skip-networking。

修改密碼

# mysql -S /usr/local/mysql57/data/mysql.sock

mysql> update mysql.user set authentication_string=password('123456') where host='localhost' and user='root';
Query OK, 0 rows affected, 1 warning (0.00 sec)
Rows matched: 1 Changed: 0 Warnings: 1

mysql> flush privileges;
Query OK, 0 rows affected (0.00 sec)

注意:

這里的update語句針對的是MySQL 5.7的操作,如果是在5.6版本,修改的應(yīng)該是password字段,而不是authentication_string。

update mysql.user set password=password('123456') where host='localhost' and user='root';

而在MySQL 8.0.11版本中,這種方式基本不可行,因?yàn)槠湟岩瞥?code>PASSWORD()函數(shù)及不再支持SET PASSWORD ... = PASSWORD ('auth_string')語法。

不難發(fā)現(xiàn),這種方式的可移植性實(shí)在太差,三個不同的版本,就先后經(jīng)歷了列名的改變,及命令的不可用。

下面,介紹另外一種更通用的做法,還是在skip-grant-tables的基礎(chǔ)上。

與上面不同的是,其會先通過flush privileges操作觸發(fā)權(quán)限表的加載,再使用alter user語句修改root用戶的密碼,如:

# bin/mysql -S /usr/local/mysql57/data/mysql.sock

mysql> alter user 'root'@'localhost' identified by '123';
ERROR 1290 (HY000): The MySQL server is running with the --skip-grant-tables option so it cannot execute this statement

mysql> flush privileges;
Query OK, 0 rows affected (0.00 sec)

mysql> alter user 'root'@'localhost' identified by '123';
Query OK, 0 rows affected (0.00 sec)

免密碼登錄進(jìn)來后,直接執(zhí)行alter user操作是不行的,因?yàn)榇藭r的權(quán)限表還沒加載??上韧ㄟ^flush privileges操作觸發(fā)權(quán)限表的加載,再執(zhí)行alter user操作。

需要注意的是,通過alter user修改密碼只適用于MySQL5.7和8.0,如果是MySQL 5.6,此處可寫成

update mysql.user set password=password('123456') where host='localhost' and user='root';

最后重啟實(shí)例

mysql> shutdown;

# bin/mysqld_safe --defaults-file=my.cnf 

需要注意的是,如果在啟動的過程中沒有指定--skip-networking參數(shù),無需重啟實(shí)例。但在網(wǎng)上看到的絕大多數(shù)方案,都是沒有指定該參數(shù),但重啟了實(shí)例,實(shí)在沒有必要。

下面對這個方案做個總結(jié):

1. 如果只添加了--skip-grant-tables,修改完密碼后,其實(shí)無需重啟,執(zhí)行flush privileges即可。

2. 從安全角度出發(fā),建議加上--skip-networking。但因其是靜態(tài)參數(shù),將其剔除掉需要重啟實(shí)例。

3. 加上--skip-networking,雖然可以屏蔽掉TCP連接,但對于本地其它用戶,只要有socket文件的可讀權(quán)限,都能無密碼登錄。還是存在安全隱患。

4. 不建議通過update的方式修改密碼,更通用的其實(shí)是alter user。

更優(yōu)雅的解法

相對于skip-grant-tables方案,我們來看看另外一種更優(yōu)雅的解法,其只會重啟一次,且基本上不存在安全隱患。

首先,依舊是關(guān)閉實(shí)例

其次,創(chuàng)建一個sql文件

寫上密碼修改語句

# vim init.sql 
alter user 'root'@'localhost' identified by '123456';

最后,使用--init-file參數(shù),啟動實(shí)例

# bin/mysqld_safe --defaults-file=my.cnf --init-file=/usr/local/mysql57/init.sql 

實(shí)例啟動成功后,密碼即修改完畢~

如果mysql實(shí)例是通過服務(wù)腳本來管理的,除了創(chuàng)建sql文件,整個操作可簡化為一步。

# service mysqld restart --init-file=/usr/local/mysql57/init.sql 

注意:該操作只適用于/etc/init.d/mysqld這種服務(wù)管理方式,不適用于RHEL 7新推出的systemd。

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。

您可能感興趣的文章:
  • mysql8.0忘記密碼修改與net命令服務(wù)名無效問題
  • MySQL8下忘記密碼后重置密碼的辦法(MySQL老方法不靈了)
  • linux下mysql忘記密碼的解決方法
  • MAC下MYSQL數(shù)據(jù)庫密碼忘記的解決辦法
  • Windows10下MySQL5.7.19安裝教程 MySQL忘記root密碼修改方法
  • mysql8.0.19忘記密碼的完美解決方法

標(biāo)簽:揚(yáng)州 新余 巴中 三門峽 贛州 商丘 南陽 貴州

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《MySQL root密碼忘記后更優(yōu)雅的解決方法》,本文關(guān)鍵詞  MySQL,root,密碼,忘記,后,更,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《MySQL root密碼忘記后更優(yōu)雅的解決方法》相關(guān)的同類信息!
  • 本頁收集關(guān)于MySQL root密碼忘記后更優(yōu)雅的解決方法的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    突泉县| 石渠县| 永丰县| 平凉市| 高碑店市| 北票市| 河间市| 西和县| 樟树市| 邵阳县| 绥化市| 米泉市| 休宁县| 融水| 兴国县| 嘉黎县| 松江区| 盐城市| 通化县| 西华县| 平果县| 揭东县| 常宁市| 宁南县| 石河子市| 密山市| 宁晋县| 军事| 阳原县| 石家庄市| 临漳县| 临武县| 塘沽区| 连州市| 敖汉旗| 五家渠市| 长沙县| 安平县| 铜山县| 象山县| 漠河县|