前言
創(chuàng)新互聯(lián)堅持“要么做到,要么別承諾”的工作理念,服務(wù)領(lǐng)域包括:成都網(wǎng)站設(shè)計、成都網(wǎng)站制作、外貿(mào)網(wǎng)站建設(shè)、企業(yè)官網(wǎng)、英文網(wǎng)站、手機端網(wǎng)站、網(wǎng)站推廣等服務(wù),滿足客戶于互聯(lián)網(wǎng)時代的府谷網(wǎng)站設(shè)計、移動媒體設(shè)計的需求,幫助企業(yè)找到有效的互聯(lián)網(wǎng)解決方案。努力成為您成熟可靠的網(wǎng)絡(luò)建設(shè)合作伙伴!
一直以來,對于MySQL root密碼的忘記,以為只有一種解法-skip-grant-tables。
問了下群里的大咖,第一反應(yīng)也是skip-grant-tables。通過搜索引擎簡單搜索了下,無論是百度,抑或Google,只要是用中文搜索,首頁都是這種解法??梢娺@種解法在某種程度上已經(jīng)占據(jù)了使用者的心智。下面具體來看看。
skip-grant-tables的解法
首先,關(guān)閉實例
這里,只能通過kill mysqld進程的方式。
注意:不是mysqld_safe進程,也切忌使用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ù),重啟實例
# bin/mysqld_safe --defaults-file=my.cnf --skip-grant-tables --skip-networking &
設(shè)置了該參數(shù),則實例在啟動過程中會跳過權(quán)限表的加載,這就意味著任何用戶都能登錄進來,并進行任何操作,相當不安全。
建議同時添加--skip-networking參數(shù)。其會讓實例關(guān)閉監(jiān)聽端口,自然也就無法建立TCP連接,而只能通過本地socket進行連接。
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版本中,這種方式基本不可行,因為其已移除了PASSWORD()
函數(shù)及不再支持SET PASSWORD ... = PASSWORD ('auth_string')
語法。
不難發(fā)現(xiàn),這種方式的可移植性實在太差,三個不同的版本,就先后經(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)
免密碼登錄進來后,直接執(zhí)行alter user
操作是不行的,因為此時的權(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';
最后重啟實例
mysql> shutdown; # bin/mysqld_safe --defaults-file=my.cnf &
需要注意的是,如果在啟動的過程中沒有指定--skip-networking參數(shù),無需重啟實例。但在網(wǎng)上看到的絕大多數(shù)方案,都是沒有指定該參數(shù),但重啟了實例,實在沒有必要。
下面對這個方案做個總結(jié):
1. 如果只添加了--skip-grant-tables,修改完密碼后,其實無需重啟,執(zhí)行flush privileges即可。
2. 從安全角度出發(fā),建議加上--skip-networking。但因其是靜態(tài)參數(shù),將其剔除掉需要重啟實例。
3. 加上--skip-networking,雖然可以屏蔽掉TCP連接,但對于本地其它用戶,只要有socket文件的可讀權(quán)限,都能無密碼登錄。還是存在安全隱患。
4. 不建議通過update的方式修改密碼,更通用的其實是alter user。
更優(yōu)雅的解法
相對于skip-grant-tables方案,我們來看看另外一種更優(yōu)雅的解法,其只會重啟一次,且基本上不存在安全隱患。
首先,依舊是關(guān)閉實例
其次,創(chuàng)建一個sql文件
寫上密碼修改語句
# vim init.sql alter user 'root'@'localhost' identified by '123456';
最后,使用--init-file參數(shù),啟動實例
# bin/mysqld_safe --defaults-file=my.cnf --init-file=/usr/local/mysql57/init.sql &
實例啟動成功后,密碼即修改完畢~
如果mysql實例是通過服務(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é)習或者工作具有一定的參考學(xué)習價值,如果有疑問大家可以留言交流,謝謝大家對創(chuàng)新互聯(lián)的支持。
網(wǎng)站欄目:MySQLroot密碼忘記后更優(yōu)雅的解決方法
轉(zhuǎn)載來于:http://jinyejixie.com/article38/jjhjsp.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供自適應(yīng)網(wǎng)站、企業(yè)建站、移動網(wǎng)站建設(shè)、定制網(wǎng)站、服務(wù)器托管、網(wǎng)站策劃
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)