方法一(先進入root權限):
# /etc/init.d/mysql stop
# mysqld_safe --user=mysql --skip-grant-tables --skip-networking &
# mysql -u root
mysql> update user set password=password("newpassword") where user='root';
mysql> flush privileges;
mysql> quit
# /etc/init.d/mysql restart
# mysql -uroot -p
enter password: <輸入新設的密碼newpassword>
mysql>
方法二:
直接使用/etc/mysql/debian.cnf文件中[client]節提供的用戶名和密碼:
# mysql -udebian-sys-maint -p
enter password: <輸入[client]節的密碼>
mysql> update user set password=password("newpassword") where user=root;
mysql> flush privileges;
mysql> quit
# mysql -uroot -p
enter password: <輸入新設的密碼newpassword>
mysql>
方法三:
這種方法我沒有進行過測試,由於個人root用戶默認密碼已經被我修改過了,那位有空測試一下,把結果告訴我,謝謝!!
# mysql -uroot -p
enter password: <輸入/etc/mysql/debian.cnf文件中[client]節提供的密碼>
方法四:
方法以下: 1, 關閉mysql服務 /etc/init.d/mysqld stop 2,使用 –skip-grant-tables選項啓動mysql服務,能夠修 改/etc/inin.d/mysqld腳本啓動位置增長此選項, vi /etc/init.d/mysqld
方法以下:
1, 關閉mysql服務
/etc/init.d/mysqld stop
2,使用 –skip-grant-tables選項啓動mysql服務,能夠修 改/etc/inin.d/mysqld腳本啓動位置增長此選項,
vi /etc/init.d/mysqld
在下面運行啓動的語句裏增長--skip-grant-tables
/usr/bin/mysqld_safe --skip-grant-tables --datadir="datadir"−−socket="datadir"−−socket="socketfile"
--log-error="errlogfile"−−pid−file="errlogfile"−−pid−file="mypidfile"
加入--skip-grant-tables的意思是啓動mysql服務的時候跳 過權限表認證。啓動後,鏈接到mysql的root不須要口令
3,從新啓動mysql服務
/etc/init.d/mysqld start
4. 修改root用戶的密碼;
mysql> update mysql.user set password=password("123456")where user=root;
mysql> flush privileges;
mysql> quit
5. 從新啓動mysql,就能夠使用 新密碼登陸了。
mysql
mysql -u root –p
輸入密碼:123456
6,關閉mysql服務
/etc/init.d/mysqld stop
7, 從新修改第2步修改的/etc/init.d/mysqld,使其保持原來不變,也就是取消--skip-grant-tables語句
8,從新 啓動mysql服務
/etc/init.d/mysqld startmysql
後記:sql
新安裝的MySQL是有密碼的,可是其實自動存儲在了某個文件夾中,我安裝的是MySQL-server-5.6.35-1.el6.x86_64.rpm,rpm安裝方式,MySQL的root密碼;默認的密碼存在:/root/.mysql_secret 這個文件夾中.///可是我就是打不開.SO..,就當忘記密碼,如何找回MySQL的初始的root密碼.找到的方法都是可行的,可是惟一很差的是可能我這個版本的設置newpasswd的時候新的密碼須要用雙引號,而原博主沒有.因此轉過來備本身使用.socket