MysqL数据库密码的管理

本文涉及的产品
RDS AI 助手,专业版
RDS MySQL DuckDB 分析主实例,集群系列 4核8GB
简介:

                 恢复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






      本文转自Jx战壕  51CTO博客,原文链接:http://blog.51cto.com/xujpxm/1386294,如需转载请自行联系原作者


相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。   相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情: https://www.aliyun.com/product/rds/mysql 
相关文章
|
7月前
|
安全 druid Nacos
0 代码改造实现应用运行时数据库密码无损轮转
本文探讨了敏感数据的安全风险及降低账密泄漏风险的策略。国家颁布的《网络安全二级等保2.0标准》强调了企业数据安全的重要性。文章介绍了Nacos作为配置中心在提升数据库访问安全性方面的应用,并结合阿里云KMS、Druid连接池和Spring Cloud Alibaba社区推出的数据源动态轮转方案。该方案实现了加密配置统一托管、帐密全托管、双层权限管控等功能,将帐密切换时间从数小时优化到一秒,显著提升了安全性和效率。未来,MSE Nacos和KMS将扩展至更多组件如NoSQL、MQ等,提供一站式安全服务,助力AI时代的应用安全。
435 14
|
8月前
|
Ubuntu 关系型数据库 MySQL
mysql8.0安装初始化不需要设定root密码?
uubntu 的mysql安装完成后无法设定root密码
491 10
|
9月前
|
关系型数据库 MySQL Linux
CentOS 7系统下详细安装MySQL 5.7的步骤:包括密码配置、字符集配置、远程连接配置
以上就是在CentOS 7系统下安装MySQL 5.7的详细步骤。希望这个指南能帮助你顺利完成安装。
2327 26
|
存储 关系型数据库 MySQL
MySQL 忘记root密码解决方案
【7月更文挑战第19天】
2249 4
|
11月前
|
存储 缓存 Java
java语言后台管理ruoyi后台管理框架-登录提示“无效的会话,或者会话已过期,请重新登录。”-扩展知识数据库中密码加密的方法-问题如何解决-以及如何重置若依后台管理框架admin密码-优雅草卓伊凡
java语言后台管理ruoyi后台管理框架-登录提示“无效的会话,或者会话已过期,请重新登录。”-扩展知识数据库中密码加密的方法-问题如何解决-以及如何重置若依后台管理框架admin密码-优雅草卓伊凡
1545 3
java语言后台管理ruoyi后台管理框架-登录提示“无效的会话,或者会话已过期,请重新登录。”-扩展知识数据库中密码加密的方法-问题如何解决-以及如何重置若依后台管理框架admin密码-优雅草卓伊凡
|
关系型数据库 MySQL 数据安全/隐私保护
windows mysql8 安装后 提示密码不对,修改下密码认证方式就可以了
windows mysql8 安装后 提示密码不对,修改下密码认证方式就可以了
2690 3
|
关系型数据库 分布式数据库 数据库
PolarDB产品使用问题之在部署PolarDB-Kubernetes时,如何设置数据库密码
PolarDB产品使用合集涵盖了从创建与管理、数据管理、性能优化与诊断、安全与合规到生态与集成、运维与支持等全方位的功能和服务,旨在帮助企业轻松构建高可用、高性能且易于管理的数据库环境,满足不同业务场景的需求。用户可以通过阿里云控制台、API、SDK等方式便捷地使用这些功能,实现数据库的高效运维与持续优化。
284 56
|
数据可视化 关系型数据库 MySQL
Mysql8 如何在 Window11系统下完成跳过密钥校验、完成数据库密码的修改?
这篇文章介绍了如何在Windows 11系统下跳过MySQL 8的密钥校验,并通过命令行修改root用户的密码。
Mysql8 如何在 Window11系统下完成跳过密钥校验、完成数据库密码的修改?
|
安全 算法 Java
数据库信息/密码加盐加密 —— Java代码手写+集成两种方式,手把手教学!保证能用!
本文提供了在数据库中对密码等敏感信息进行加盐加密的详细教程,包括手写MD5加密算法和使用Spring Security的BCryptPasswordEncoder进行加密,并强调了使用BCryptPasswordEncoder时需要注意的Spring Security配置问题。
1187 0
数据库信息/密码加盐加密 —— Java代码手写+集成两种方式,手把手教学!保证能用!
|
存储 关系型数据库 MySQL
【赵渝强老师】解决MySQL丢失root用户密码
本文介绍了MySQL数据库中用户密码存储的变化,以及如何通过特殊方法重置root用户的密码。从MySQL 5.7版本开始,密码字段由“password”改为“authentication_string”。文章详细列出了重置密码的步骤,并提供了相关代码示例和视频教程。
421 0

推荐镜像

更多