ICode9

精准搜索请尝试: 精确搜索
首页 > 数据库> 文章详细

忘记密码,重置MySQL管理密码

2021-05-13 14:05:29  阅读:183  来源: 互联网

标签:tables skip 重置 密码 mysql dbsvr1 root MySQL


登录MySQL
默认情况下,msyql命令会连接本机的MySQL服务。但在需要的时候,可以通过 -h 选项指定远程主机;如果端口不是3306,还可以通过大写的 -P 选项指定:
mysql -h主机地址 -u用户名 -p密码 -P 3306

忘记密码,重置MySQL管理密码
一、首先停止已运行的MySQL服务程序
[root@dbsvr1 ~]# service mysql stop            //停止服务
[root@dbsvr1 ~]# service mysql status         //确认状态


二、然后跳过授权表启动MySQL服务程序
这一步主要利用mysqld的 --skip-grant-tables选项,具体操作时可选择不同方式,但本质上是一样的。以下提供三种方式,任选其中一种都可以。
方式1(推荐),执行mysql脚本起服务,末尾加 --skip-grant-tables 参数:
[root@dbsvr1 ~]# service mysql start --skip-grant-tables   //跳过授权表启动服务
[root@dbsvr1 ~]# service mysql status          //确认状态
                          MySQL running         


方式2,执行mysqld_safe进程,添加 --skip-grant-tables 参数:
[root@dbsvr1 ~]# mysqld_safe --user=mysql --skip-grant-tables &


方式3,修改my.cnf配置,添加 skip_grant_tables=1启动设置:
[root@dbsvr1 ~]# vim /etc/my.cnf
   [mysqld]
   skip_grant_tables=1
[root@dbsvr1 ~]# service mysql start              //启动服务
[root@dbsvr1 ~]# service mysql status         //确认状态
                            MySQL running
为了避免冲突,上述三种方式不要同时使用。若要分别测试不同方式,同样要先停用其他方式启动的MySQL服务程序(直接service mysql stop即可)。

使用mysql命令连接到MySQL服务,重设root的密码
由于前一步启动的MySQL服务跳过了授权表,所以可以root从本机直接登录,不需要验证密码:
[root@dbsvr1 ~]# mysql -u root
进入 mysql> 环境后,通过修改mysql库中user表的相关记录,重设root用户从本机登录的密码:
mysql> UPDATE mysql.user SET password=PASSWORD('1234567')  WHERE user='root' AND host='localhost';              //重设root的密码
mysql> FLUSH PRIVILEGES;                                  //刷新授权表
mysql> exit                                              //退出mysql> 环境
通过执行“FLUSH PRIVILEGES;”可使授权表立即生效,对于正常运行的MySQL服务,也可以用上述方法来修改密码,不用重启服务。本例中因为是恢复密码,最好重启MySQL服务程序,所以上述“FLUSH PRIVILEGES;”操作可跳过。

重新以正常方式启动MySQL服务程序,验证新密码

如果前面是修改/etc/my.cnf配置的方法来跳过授权表,则重置root密码后,应去除相应的设置以恢复正常:
[root@dbsvr1 ~]# vim /etc/my.cnf
[mysqld]
#skip_grant_tables=1                              //注释掉或删除此行

 

标签:tables,skip,重置,密码,mysql,dbsvr1,root,MySQL
来源: https://www.cnblogs.com/liangyd/p/14764181.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有