本案例要求熟悉MySQL管理密码的控制,完成以下任务操作:
1)练习重置MySQL管理密码的操作
2)通过正常途径设置MySQL数据库的管理密码
实现此案例需要按照如下步骤进行。

步骤一:重置MySQL管理密码

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

[root@dbsvr1 ~]# service mysql stop                         //停止服务
Shutting down MySQL...                              [确定]
[root@dbsvr1 ~]# service mysql status                          //确认状态
MySQL is not running                            [失败]

2)然后跳过授权表启动MySQL服务程序
这一步主要利用mysqld的 --skip-grant-tables选项,具体操作时可选择不同方式,但本质上是一样的。以下提供三种方式,任选其中一种都可以。
方式1(推荐),执行mysql脚本起服务,末尾加 --skip-grant-tables 参数:

[root@dbsvr1 ~]# 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)                                   [确定]

为了避免冲突,上述三种方式不要同时使用。若要分别测试不同方式,同样要先停用其他方式启动的MySQL服务程序(直接service mysql stop即可)。
3)使用mysql命令连接到MySQL服务,重设root的密码
由于前一步启动的MySQL服务跳过了授权表,所以可以root从本机直接登录,不需要验证密码

[root@dbsvr1 ~]# mysql -u root
Welcome to the MySQL monitor.  Commands end with ; or \g.
Your MySQL connection id is 1
Server version: 5.6.15 MySQL Community Server (GPL)Copyright (c) 2000, 2013, Oracle and/or its affiliates. All rights reserved.Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.mysql>
进入 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;                                 //刷新授权表
Query OK, 0 rows affected (0.00 sec)
mysql> exit                                              //退出mysql> 环境
Bye

通过执行“FLUSH PRIVILEGES;”可使授权表立即生效,对于正常运行的MySQL服务,也可以用上述方法来修改密码,不用重启服务。本例中因为是恢复密码,最好重启MySQL服务程序,所以上述“FLUSH PRIVILEGES;”操作可跳过。
4)重新以正常方式启动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.
Your MySQL connection id is 2
Server version: 5.6.15 MySQL Community Server (GPL)Copyright (c) 2000, 2013, Oracle and/or its affiliates. All rights reserved.Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.mysql>

步骤二:正常设置MySQL管理密码

正常的前提是:已知当前MySQL管理用户(root)的密码。
1)方法1,在Shell命令行下设置

使用mysqladmin管理工具,需要验证旧的密码。比如,以下操作将会把root的密码设置为 1234567:

[root@dbsvr1 ~]# mysqladmin -u root -p password '1234567'
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)
Rows matched: 1  Changed: 0  Warnings: 0
mysql> FLUSH PRIVILEGES;                                 //刷新授权表
Query OK, 0 rows affected (0.00 sec)

在上述方法中,需要特别注意:当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 statementmysql> GRANT all ON *.* TO root@localhost IDENTIFIED BY '1234567';
ERROR 1290 (HY000): The MySQL server is running with the --skip-grant-tables option so it cannot execute this statement

MySQL(密码恢复及设置)相关推荐

  1. java 设置mysql 密码_Mysql修改设置root密码的命令及方法

    Mysql数据库是PHP网站开发必不可少的组合,通常PHP连接 Mysql都是通过root用户名和密码连接,Mysql在安装时root初始默认密码为空,在安装使用PHP开源系统时,都需要填写连接Mys ...

  2. mysql密码复杂度设置

    mysql密码复杂度策略的插件,默认位置:/usr/local/mysql8/lib/plugin/validate_password.so 插件名字叫 validate_password,如果没有安 ...

  3. mamp设置mysql密码_MAMP中设置Mysql root密码

    作为一名大三学生,我的技术还很薄弱,最近想学习一下PHP+mysql进行web开发,由于用的是mac机器,并且希望快速入门而不必将时间花费在环境搭建上,我选择了使用MAMP集成开发环境,我会慢慢将我的 ...

  4. 富士施乐2263 2265 忘记密码 恢复出厂设置

    在控制面板,按住0(持续5秒不放),同时再按最大的启动键(绿色圆形),进入到一个新的界面,在输入框中,输入密码6789,手指按屏幕上的确认.后面随便你们设吧~

  5. MySQL授权用户及密码恢复设置

    MySQL密码恢复及设置 1.停止MySQL服务程序. 2.跳过授权表启动MySQL服务程序 skip-grant-tables(添加在配置文件) 3.重设root密码(更新user表记录) 4.以正 ...

  6. mysql恢复授权表登录_MySQL授权用户及密码恢复设置

    MySQL密码恢复及设置 1.停止MySQL服务程序. 2.跳过授权表启动MySQL服务程序 skip-grant-tables(添加在配置文件) 3.重设root密码(更新user表记录) 4.以正 ...

  7. mysql密码过期设置,mysql5.6.X和mysql8.0.X密码过期策略

    mysql密码过期策略设置 关于mysql5.6.X和mysql8.0.X配置密码过期策略的学习心得 一.mysql5.6.X配置密码过期策略 网上说的方式,但这不适用于低于5.7.4版本 二.mys ...

  8. php密码不能为空,PHPJN0001:phpmyadmin 允许密码为空 设置

    phpmyadmin连接mysql数据库,出于安全考虑,默认不允许使用空密码连接数据库.因为数据库一般都设置密码访问. 但如果只是本机环境测试使用,每隔一段时间都需要填写密码,不是很方便. 如果没有修 ...

  9. Mysql索引,用户及授权(root密码恢复)

    目录 一.MySQL索引 1.MySQL索引的基本概念 1)优缺点 2)分类 2.创建索引 1)普通索引index 3.查看索引 4.删除索引 二.用户及授权 1.授权 2.相关查询指令 3.授权库m ...

  10. linux中MySQL密码的恢复方法

    MySQL密码的恢复方法之一 1.首先确认服务器出于安全的状态,也就是没有人能够任意地连接MySQL数据库. 因为在重新设置MySQL的root密码的期间,MySQL数据库完全出于没有密码保护的 状态 ...

最新文章

  1. R语言使用coin包应用于独立性问题的置换检验(permutation tests、响应变量是否独立于组、两个数值变量是独立的吗、两个分类变量是独立的吗)、以及coin包的常用置换检验函数
  2. shell脚本连接ftp推送文件夹_Linux下使用Shell脚本实现FTP自动上传和下载文件
  3. 第五篇第二节T语言实例开发,百变字符(版本5.3)
  4. 问题 D: AC自动机(二分,第一个等于和最后一个等于)
  5. (计算机显示器主屏幕区域)桌面造句,部编版《语文园地四》教学反思模板(11页)-原创力文档...
  6. 随想录(ccpp之间的相互调用)
  7. Mac系统如何通过自带的工具进行磁盘修复
  8. VsCode 配置java环境(详细教程)
  9. java和eova的关系_eova ,一套jfinal开发框架,方便学习与 Jsp/Servlet 262万源代码下载- www.pudn.com...
  10. logit和logistic模型
  11. dnspod动态解析linux,NAS折腾记 篇一:五分钟搞定威联通DNSPOD动态域名解析-简单教程+问题解决...
  12. 如何演示扇形面积公式推导过程
  13. 关于三极管,我忽视了两点
  14. bluetooth a2dpsink
  15. 软件设计模式——单例模式
  16. CentOS 使用ifconfig没有显示ip
  17. RTX51 Tiny用户指南(一)
  18. P2物理引擎中文文档
  19. python创建学生字典_用python创建简单字典
  20. 如何让 Eclipse Java EE 版安装 CDT 以同时支持 Java 和 C/C++ 开发

热门文章

  1. codeforces 129C - Statues 图论 DFS
  2. 史上最完整的《指环王》魔戒战争大事记(编年体长文)
  3. python清空画布_Python3 tkinter基础 Canvas delete 删除画布中的所有图形
  4. Linux TC 流量限速
  5. linux中cd中文意思,linux中cd ~和!!是什么意思?
  6. icloud显示账户详情不可用_iCloud提示账户详情不可用怎么办 iphone提示账户详情不可用的解决方法...
  7. 炸!撩下 OLAP 数据分析的黑马神器 ClickHouse
  8. 如何搭建ftp服务器实现文件共享
  9. 【神经网络】一文带你轻松解析神经网络(附实例恶搞女友)
  10. win10u盘被写保护怎么解除_磁盘被写保护怎么解除,小编告诉你如何解决U盘磁盘被写保护...