首页 > 系统 > Linux > 正文

linux重置mysql root密码的6种方法

2024-08-27 23:59:19
字体:
来源:转载
供稿:网友

在linux系统中重启root密码也是非常的简单并且方法多了去了,下面小编为各位整理了一些常用的root密码重置方法,希望例子能给大家带来帮助.

shell脚本重启mysql密码

注:记得给此脚本属于执行权限哦,chmod u+x reset_mysql_root_password.sh,此shell脚本如下:

  1. #!/bin/bash 
  2. PATH=/bin:/sbin:/usr/bin:/usr/sbin:/usr/local/bin:/usr/local/sbin:~/bin 
  3. export PATH 
  4. # Check if user is root 
  5. if [ $(id -u) != "0" ]; then 
  6.     printf "Error: You must be root to run this script!\n" 
  7.     exit 1 
  8. fi 
  9. echo "=========================================================================\n" 
  10. printf "Reset MySQL root Password for LNMP  ,  Written by Licess \n" 
  11. printf "=========================================================================\n" 
  12. printf "LNMP is a tool to auto-compile & install Nginx+MySQL+PHP on Linux \n" 
  13. printf "This script is a tool to reset mysql root password for lnmp \n" 
  14. printf "For more information please visit http://www.111cn.net \n" 
  15. printf "\n" 
  16. printf "Usage: sh reset_mysql_root_password.sh\n" 
  17. printf "=========================================================================\n" 
  18. mysql_root_password="" 
  19. read -p "(Please input New MySQL root password):" mysql_root_password 
  20. if [ "$mysql_root_password" = "" ]; then 
  21. echo "Error: Password can't be NULL!!\n" 
  22. exit 1 
  23. fi 
  24. printf "Stoping MySQL...\n" 
  25. /etc/init.d/mysql stop 
  26. printf "Starting MySQL with skip grant tables\n" 
  27. /usr/local/mysql/bin/mysqld_safe --skip-grant-tables >/dev/null 2>&1 & 
  28. printf "using mysql to flush privileges and reset password\n" 
  29. sleep 10 
  30. printf "update user set password = Password('$mysql_root_password') where User = 'root'\n" 
  31. /usr/local/mysql/bin/mysql -u root mysql << EOF 
  32. update user set password = Password('$mysql_root_password') where User = 'root'
  33. EOF 
  34. reset_status=`echo $?` 
  35. if [ $reset_status = "0" ]; then 
  36. printf "Password reset succesfully. Now killing mysqld softly\n" 
  37. killall mysqld  //Vevb.com 
  38. sleep 10 
  39. printf "Restarting the actual mysql service\n" 
  40. /etc/init.d/mysql start 
  41. printf "Password successfully reset to '$mysql_root_password'\n" 
  42. else 
  43. printf "Reset MySQL root password failed!\n" 
  44. fi 

方法二:利用root管理员来操作,系统管理员root进入shell,代码如下:

  1. #service mysqld stop 
  2. #mysqld_safe –skip-grant-tables & (我的mysqld_safe在/usr/bin,如果你的mysqld_safe不在PATH路径里面,那么这里要使用绝对路径) 
  3. 这个时候root的密码为空,我们就可以免认证登录了 
  4. #mysql -u root 

方法三:使用mysqladmin,代码如下:

  1. # ./mysqladmin -u root password 'newpassword' 
  2. # ./mysqladmin -u root -h host_name password 'newpassword' 
  3. Usually mysqladmin's path is /usr/bin, host_name is your real host name, e.g. localhost.localdomain. 

password后面的引号不是必须的,不过如果密码包含空格或者一些特殊的符号,需要用引号.

方法四:利用mysql SET PASSWORD命令,代码如下:

  1. # ./mysql -u root 
  2. mysql> SET PASSWORD FOR 'root'@'localhost' = PASSWORD('newpassword'); 
  3. mysql> SET PASSWORD FOR 'root'@'host_name' = PASSWORD('newpassword'); 

方法五:使用UPDATE语句更新user表重置ROOT密码,代码如下:

  1. # ./mysql -u root 
  2. mysql> UPDATE mysql.user SET Password = PASSWORD('newpassword') WHERE User = 'root'; 
  3. 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.

  1. # mysqld_safe –skip-grant-tables & 
  2.  
  3. //或, 
  4.  
  5. # mysqld_safe --skip-grant-tables >/dev/null 2>&1 & 

提示:mysqld_safe一般在/usr/local/mysql/bin/目录下.

3、登陆MYSQL

完成上述两步以后就可以不用密码进入MySQL了.

  1. # mysql -u root 
  2. //或, 
  3. # /usr/local/mysql/bin/mysql -u root mysql 

4、更改ROOT密码,以下几句依次执行:

  1. use mysql; 
  2. select host, user, password from user; 
  3. update user set password=password(“newpassword”) where user=”root” 
  4. flush privileges; 

5.退出控制台,重启MYSQL服务.

  1. service mysqld restart 
  2. //或, 
  3. /etc/init.d/mysql restart

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表