恢复MySQL管理密码

实验内容:

一、在忘记密码的情况下,修改密码

二、在原有密码的基础上修改密码

1.恢复MySQL管理密码

1)首先停止已运行的MySQL服务程序

# service mysql stop                         //先停止服务

Shutting down MySQL...                             [确定]

# service mysql status                         //确认状态

MySQL is not running

[失败]

2)然后跳过授权表启动MySQL服务程序

这一步主要利用mysqld的 --skip-grant-tables选项,具体操作时可选择不同方式,但本质上是一样的。以下提供三种方式,任选其中一种都可以。

方式1(推荐):

执行mysql脚本起服务,末尾加 --skip-grant-tables 参数:

# service mysql start --skip-grant-tables

Starting MySQL............                                 [确定]

[root@dbsvr1 ~]# service mysql status

MySQL running (45640)                                     [确定]

方式2:

执行mysqld_safe进程,添加 --skip-grant-tables 参数:

[root@dbsvr1 ~]# mysqld_safe --user=mysql --skip-grant-tables &

[1] 46076

140110 09:58:39 mysqld_safe Logging to '/var/lib/mysql/dbsvr1.tarena.com.err'.

140110 09:58:39 mysqld_safe Starting mysqld daemon with databases from /var/lib/mysql

方式3:

修改my.cnf配置,添加 skip_grant_tables=1启动设置:

[root@dbsvr1 ~]# vim /etc/my.cnf

[mysqld]

skip_grant_tables=1

.. ..

[root@dbsvr1 ~]# service mysql start

Starting MySQL                                             [确定]

[root@dbsvr1 ~]# service mysql status

MySQL running (46580)                                     [确定]

3)使用mysql命令连接到MySQL服务,重设root的密码

由于前一步启动的MySQL服务跳过了授权表,所以可以root从本机直接登录,不需要验证密码:

# mysql -u root //直接登录即可

Welcome to the MySQL monitor. Commands end with ; or \g.

mysql>

4)进入 mysql> 环境后,通过修改mysql库中user表的相关记录,重设root用户从本机登录的密码:

mysql> UPDATE mysql.user SET password=PASSWORD('1234567')

-> WHERE user='root' AND host='localhost';             //重设root的密码

Query OK, 0 rows affected (0.17 sec)

Rows matched: 1 Changed: 0 Warnings: 0

mysql> FLUSH PRIVILEGES;

//flush privileges 刷新授权表

Query OK, 0 rows affected (0.00 sec)

mysql> exit                                             //退出mysql> 环境

Bye

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

如果前面是修改/etc/my.cnf配置的方法来跳过授权表,则重置root密码后,应去除相应的设置以恢复正常:

[root@dbsvr1 ~]# vim /etc/my.cnf

[mysqld]

#skip_grant_tables=1                             //注释掉或删除此行,如果没用方式三不用修改

... ..

按正常方式,通过mysql脚本重启服务即可:

[root@dbsvr1 ~]# service mysql restart

Shutting down MySQL.. [确定]

Starting MySQL. [确定]

验证无密码登录时,将会被拒绝:

.[root@dbsvr1 ~]# mysql -u root

ERROR 1045 (28000): Access denied for user 'root'@'localhost' (using password: NO)

只有提供重置后的新密码,才能成功登入:

[root@dbsvr1 ~]# mysql -u root -p

Enter password:

Welcome to the MySQL monitor. Commands end with ; or \g.

2.正常设置MySQL管理密码(在原密码的基础上修改)

正常的前提是:已知当前MySQL管理用户(root)的密码。

1)方法1:

在Shell命令行下设置

#mysqladmin –uroot –p password “123”;    //新密码

Enter password://输入旧的密码

2)方法2,以root登入mysql> 后,使用SET PASSWORD指令设置

这个与新安装MySQL-server后首次修改密码时要求的方式相同,平时也可以用

mysql> SET PASSWORD FOR root@localhost=PASSWORD('1234567')

Query OK, 0 rows affected (0.16 sec)

3)方法3,以root登入mysql> 后,使用GRANT授权工具设置

mysql> GRANT all ON *.* TO root@localhost IDENTIFIED BY '1234567';

Query OK, 0 rows affected (0.00 sec)

4)方法4,以root登入mysql> 后,使用UPDATE更新相应的表记录

这种方法与恢复密码时的操作相同:

mysql> UPDATE mysql.user SET password=PASSWORD('1234567') //用密码函数生成密码

-> WHERE user='root' AND host='localhost';             //重设root的密码

Query OK, 0 rows affected (0.17 sec)

实验总结:

1、为了避免冲突,跳过授权表修改mysql密码的三种方式不要同时使用。若要分别测试不同方式,同样要先停用其他方式启动的MySQL服务程序(直接service mysql stop即可)。

2、通过执行“FLUSH PRIVILEGES;”可使授权表立即生效,对于正常运行的MySQL服务,也可以用上述方法来修改密码,不用重启服务。本例中因为是恢复密码,最好重启MySQL服务程序,所以上述“FLUSH PRIVILEGES;”操作可跳过。

3在正常设置密码方法中,需要特别注意:当MySQL服务程序以 --skip-grant-tables 选项启动时,如果未

执行“FLUSH PRIVILEGES;”操作,是无法通过SET PASSWORD或者GRANT方式来设置密码的。

比如,验证这两种方式时,都会看到ERROR 1290的出错提示:

mysql> SET PASSWORD FOR root@localhost=PASSWORD('1234567');

ERROR 1290 (HY000): The MySQL server is running with the --skip-grant-tables option so it cannot execute this statement

转载于:https://blog.51cto.com/xujpxm/1386294

MysqL数据库密码的管理相关推荐

  1. 详解:MySQL数据库的权限管理和运维实操

    详解:MySQL数据库的权限管理 一.MYSQL权限简介 关于mysql的权限简单的理解就是mysql允许你做你权利以内的事情,不可以越界.比如只允许你执行select操作,那么你就不能执行updat ...

  2. 如何在linux系统下修改mysql密码_如何在linux下修改mysql数据库密码?linux修改数据库密码的方法...

    本篇文章给大家带来的内容是介绍如何在linux下修改mysql数据库密码?linux修改数据库密码的方法.有一定的参考价值,有需要的朋友可以参考一下,希望对你们有所帮助. Linux下修改Mysql的 ...

  3. centos修改mysql密码_WAMP下修改MYSQL数据库密码

    WAMP就是Windows Apache Mysql PHP集成安装环境,即在window下的apache.php和mysql的服务器软件.用来学习.调试.运行php,mysql都是非常简便的.初次安 ...

  4. mac mysql 账户密码忘记_MAC下MYSQL数据库密码忘记的解决办法

    Mac操作系统下MYSQL数据库密码忘记的快速解决办法 1. 在系统偏好 中,中止MYSQL服务.: 2. cd/usr/local/mysql-...../bin sudo ./mysqld_saf ...

  5. MySQL数据库密码忘了,怎么修改密码,找回密码。

    MySQL数据库密码忘了,怎么修改密码,找回密码. 当我们忘记mysql数据库密码时我们就无法正常进入数据库,也就无法修改密码,那么这时该怎么修改密码呢,这里教大家一个简单常用修改密码的方式. 1.打 ...

  6. 如何修改MySQL数据库密码

    如何修改MySQL数据库密码 写的比较好,此处收藏一下,感谢博主的分享:原博客地址 方法 1: 用 SET PASSWORD 命令 首先登录 MySQL. 格式:mysql> set passw ...

  7. phpwind mysql 密码_PhpWind教程:MySQL数据库密码修改方法

    问题: MySQL数据库密码如何修改? 解决方法: 方法一 使用phpmyadmin,这是最简单的了,修改mysql库的user表, 不过别忘了使用PASSWORD函数. 方法二 使用mysqladm ...

  8. MySQL数据库密码破解

    研究MySQL数据库的加解密方式,在网络攻防过程中具有重要的意义:试想一旦获取了网站一定的权限后,如果能够获取MySQL中保存用户数据,通过解密后,即可通过正常途径来访问数据库:一方面可以直接操作数据 ...

  9. 更改Mysql数据库密码

    今天Navicat连接MySql数据库报如下错误,明明密码没有错误呀,可就是登不上,只能重新修改密码. 关闭正在运行的MySQL. 打开DOS窗口,转到mysql\bin目录. 输入mysqld -- ...

最新文章

  1. CV07-DeepLab v3+笔记
  2. 关于c语言中负数位移位操作的漫谈
  3. 8.元组tup.rs
  4. 中国移动wlan优化app-截图
  5. Linux笔记-grep -v功能相关说明
  6. ACKRec:注意力异构图卷积深度知识推荐器 SIGIR 2020
  7. CCS的c语言编程,CCS_C语言编程
  8. Git(码云)如何把本地仓库提交到远程仓库
  9. oracle11g dataguard
  10. HTL/TTL转光纤模块
  11. K8S学习之污点容忍
  12. amesim子模型_AMESim进行实际物理建模及建模的一般过程
  13. 说说CAP 理论是什么?
  14. 《校园墙》小程序可行性分析
  15. android模拟点击滑动,android模拟点击,长按和滑动
  16. ElasticSearch6.5.4三中文以及拼音的搜索
  17. SAP MM 采购预付款管理初探
  18. 作业6:基于CNN的XO识别 深度学习 手搓卷积代码
  19. 计算机考研英语词汇,考研英语词汇到底该怎么记
  20. 微软苏菲rt能装鸿蒙,评测人员称Surface RT设计漂亮但系统存不足

热门文章

  1. 【Verilog HDL 训练】第 09 天(按键消抖)
  2. 【 MATLAB 】序列运算之序列移位的函数实现
  3. JavaScript继承的多种方式和优缺点
  4. 由一行文本输入框引发的思考
  5. Rust基础笔记:Getting input from the console
  6. jQuery常用方法一览
  7. AMD:浏览器中的模块规范
  8. linux 用户行为审计update1
  9. vscode折叠/展开所有区域代码快捷键
  10. Vivado中debug用法