在linux系統中重啟root密碼也是非常的簡單并且方法多了去了,下面小編為各位整理了一些常用的root密碼重置方法,希望例子能給大家帶來幫助.
shell腳本重啟mysql密碼
注:記得給此腳本屬于執行權限哦,chmod u+x reset_mysql_root_password.sh,此shell腳本如下:
- #!/bin/bash
- PATH=/bin:/sbin:/usr/bin:/usr/sbin:/usr/local/bin:/usr/local/sbin:~/bin
- export PATH
- # Check if user is root
- if [ $(id -u) != "0" ]; then
- printf "Error: You must be root to run this script!\n"
- exit 1
- fi
- echo "=========================================================================\n"
- printf "Reset MySQL root Password for LNMP , Written by Licess \n"
- printf "=========================================================================\n"
- printf "LNMP is a tool to auto-compile & install Nginx+MySQL+PHP on Linux \n"
- printf "This script is a tool to reset mysql root password for lnmp \n"
- printf "For more information please visit http://www.111cn.net \n"
- printf "\n"
- printf "Usage: sh reset_mysql_root_password.sh\n"
- printf "=========================================================================\n"
- mysql_root_password=""
- read -p "(Please input New MySQL root password):" mysql_root_password
- if [ "$mysql_root_password" = "" ]; then
- echo "Error: Password can't be NULL!!\n"
- exit 1
- fi
- printf "Stoping MySQL...\n"
- /etc/init.d/mysql stop
- printf "Starting MySQL with skip grant tables\n"
- /usr/local/mysql/bin/mysqld_safe --skip-grant-tables >/dev/null 2>&1 &
- printf "using mysql to flush privileges and reset password\n"
- sleep 10
- printf "update user set password = Password('$mysql_root_password') where User = 'root'\n"
- /usr/local/mysql/bin/mysql -u root mysql << EOF
- update user set password = Password('$mysql_root_password') where User = 'root';
- EOF
- reset_status=`echo $?`
- if [ $reset_status = "0" ]; then
- printf "Password reset succesfully. Now killing mysqld softly\n"
- killall mysqld //Vevb.com
- sleep 10
- printf "Restarting the actual mysql service\n"
- /etc/init.d/mysql start
- printf "Password successfully reset to '$mysql_root_password'\n"
- else
- printf "Reset MySQL root password failed!\n"
- fi
方法二:利用root管理員來操作,系統管理員root進入shell,代碼如下:
- #service mysqld stop
- #mysqld_safe –skip-grant-tables & (我的mysqld_safe在/usr/bin,如果你的mysqld_safe不在PATH路徑里面,那么這里要使用絕對路徑)
- 這個時候root的密碼為空,我們就可以免認證登錄了
- #mysql -u root
- >
方法三:使用mysqladmin,代碼如下:
- # ./mysqladmin -u root password 'newpassword'
- # ./mysqladmin -u root -h host_name password 'newpassword'
- Usually mysqladmin's path is /usr/bin, host_name is your real host name, e.g. localhost.localdomain.
password后面的引號不是必須的,不過如果密碼包含空格或者一些特殊的符號,需要用引號.
方法四:利用mysql SET PASSWORD命令,代碼如下:
- # ./mysql -u root
- mysql> SET PASSWORD FOR 'root'@'localhost' = PASSWORD('newpassword');
- mysql> SET PASSWORD FOR 'root'@'host_name' = PASSWORD('newpassword');
方法五:使用UPDATE語句更新user表重置ROOT密碼,代碼如下:
- # ./mysql -u root
- mysql> UPDATE mysql.user SET Password = PASSWORD('newpassword') WHERE User = 'root';
- mysql> FLUSH PRIVILEGES;
方法六:啟動MYSQL的安全模式重置ROOT密碼,代碼如下:
1、停止MySQL進程
執行:/etc/init.d/mysql stop,具體位置可能隨系統不同而不同,也可能是/etc/init.d/mysql,/etc/init.d/mysqld等路徑,或下面直接終止,最好不要使用下面這個強制語句.
# killall -TERM mysqld
2、以安全模式啟動MySQL.
- # mysqld_safe –skip-grant-tables &
- //或,
- # mysqld_safe --skip-grant-tables >/dev/null 2>&1 &
提示:mysqld_safe一般在/usr/local/mysql/bin/目錄下.
3、登陸MYSQL
完成上述兩步以后就可以不用密碼進入MySQL了.
- # mysql -u root
- //或,
- # /usr/local/mysql/bin/mysql -u root mysql
4、更改ROOT密碼,以下幾句依次執行:
- use mysql;
- select host, user, password from user;
- update user set password=password(“newpassword”) where user=”root”
- flush privileges;
5.退出控制臺,重啟MYSQL服務.
- service mysqld restart
- //或,
- /etc/init.d/mysql restart
新聞熱點
疑難解答