shell重置mysql密码_linux重置mysql root密码的shell脚本

在linux下忘mysql root密码怎么办?

今天和大家分享一个重置root密码的shell脚本。只有把要重置的密码输入就可以了。

脚本下载地址:[点我下载](http://image.gwalker.cn/Uploads_ArticleFiles_20140525_5380d315bb895.zip "点我下载")

操作如下图:

![](http://image.gwalker.cn/Uploads_ArticleFiles_20140525_m_5380d26936f19.jpg)

注:记得给此脚本属于执行权限哦。(chmod u+x reset_mysql_root_password.sh)

此shell脚本如下:

```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.lnmp.org \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

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

```

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值