技术文摘
Linux 下忘记 MySQL 密码
Linux 下忘记 MySQL 密码
在 Linux 环境中使用 MySQL 数据库时,忘记密码是一个常见且棘手的问题。不过,只要掌握正确的方法,就能顺利解决。
我们需要以安全模式启动 MySQL。不同的 Linux 发行版操作略有不同,但大致思路一致。以常见的 CentOS 为例,我们可以先停止正在运行的 MySQL 服务,使用命令 “systemctl stop mysqld”。然后,通过修改启动参数来以安全模式启动 MySQL。编辑 MySQL 的配置文件,一般路径为 “/etc/my.cnf”。在 [mysqld] 部分添加 “skip-grant-tables” 这一行,这一参数的作用是让 MySQL 在启动时跳过权限验证,从而可以无需密码直接登录。
完成配置修改后,重新启动 MySQL 服务,“systemctl start mysqld”。接着,使用 “mysql” 命令直接登录数据库,此时不需要输入密码。登录成功后,我们就进入了 MySQL 的命令行界面。
接下来要做的就是修改密码。在 MySQL 中,用户信息存储在 “mysql” 数据库的 “user” 表中。我们先切换到 “mysql” 数据库,使用命令 “use mysql;”。然后,使用 “UPDATE” 语句来修改密码。例如,如果要将 root 用户的密码修改为 “newpassword”,可以执行命令 “UPDATE user SET authentication_string=PASSWORD('newpassword') WHERE User='root' AND Host='localhost';”。这里的 “authentication_string” 字段存储着加密后的密码。
修改完成后,不要忘记刷新权限,使用 “FLUSH PRIVILEGES;” 命令。之后,退出 MySQL 命令行界面,使用 “exit” 命令。
最后,我们需要恢复 MySQL 的正常启动模式。再次编辑 MySQL 配置文件,将之前添加的 “skip-grant-tables” 这一行删除,保存并退出。然后重新启动 MySQL 服务,“systemctl restart mysqld”。
至此,在 Linux 下忘记 MySQL 密码的问题就得到了解决。掌握这个方法,当遇到此类问题时,就能迅速恢复对 MySQL 数据库的访问权限,确保工作和项目的顺利进行。
- MySQL学习:用命令将SQL查询结果导出到指定文件
- MySQL实现行号排序及同表数据上下行比较排序
- 探秘 MySQL 慢查询开启方法与慢查询日志原理
- 必藏!MySQL常见面试题,面试用得上
- MySQL索引原理学习方法与个人心得总结
- 从零开始认识SQL注入:究竟什么是SQL注入
- MySQL 慢查询日志:MySQL 记录日志的一种功能
- 数据库高并发请求下如何确保数据完整性?深度解析MySQL/InnoDB加锁机制
- MySQL 中 I/O 错误的成因、解决办法与优化建议
- MySQL 中创建测试父表、子表及测试用例归纳总结
- MySQL索引:是什么与如何使用(详细整理)
- MySQL 里的 Buffered 和 Unbuffered queries 以及 pdo 的非缓存查询示例
- 外键 DDL 在 Oracle 正常运行,在 MySQL 报错及解决办法
- MySQL实现组内排序:模拟Oracle中rank()函数功能
- 深入解析 MyBatis 逆向工程并附简单教程与代码