当前位置: 首页 > news >正文

详细分析linux中的MySql跳过密码验证以及Bug(图文)

目录

  • 1.问题所示
  • 2. 基本知识
  • 3. 解决方法
    • 3.1 跳过验证Bug
    • 3.2 设定初始密码

1.问题所示

在这里插入图片描述

发现密码验证错误,遗失密码

2. 基本知识

  1. 停止MySQL服务sudo systemctl stop mysql

  2. 以跳过权限表模式启动MySQLsudo mysqld_safe --skip-grant-tables &

  3. 登录MySQLmysql -u root

  4. 重置root用户密码:(不同版本不一,如果执行出错,可看下文)

ALTER USER 'root'@'localhost' IDENTIFIED BY 'new_password';
FLUSH PRIVILEGES;
  1. 重新启动MySQL服务sudo systemctl start mysql

在这里插入图片描述

3. 解决方法

根据上述的基本知识操作进行演示,过程中可能会出现个别Bug

3.1 跳过验证Bug

跳过验证的时候,如果出现如下提示:

root@iZ7xv98hm4hq0dd3xv23vuZ:~# sudo mysqld_safe --skip-grant-tables &
[1] 720919
root@iZ7xv98hm4hq0dd3xv23vuZ:~# 2024-09-02T14:05:11.207426Z mysqld_safe Logging to '/var/log/mysql/error.log'.
2024-09-02T14:05:11.233525Z mysqld_safe A mysqld process already exists[1]+  Exit 1                  sudo mysqld_safe --skip-grant-tables

截图如下:

在这里插入图片描述

先确保所有 MySQL 相关的进程都被停止:ps aux | grep mysqld

如果看到任何运行中的 MySQL 进程,使用 kill 或 kill -9 命令手动终止它们:sudo kill -9 <PID>

在这里插入图片描述

3.2 设定初始密码

使用的是 MySQL 5.7 或更高版本,密码字段通常是 authentication_string,但 PASSWORD() 函数可能已被弃用

UPDATE mysql.user SET authentication_string='123456' WHERE User='root' AND Host='localhost';

使用的是 MySQL 5.6 或更低版本,密码字段可能是 password,可以使用以下命令:

UPDATE mysql.user SET password=PASSWORD('123456') WHERE User='root' AND Host='localhost';

之后统一执行:`FLUSH PRIVILEGES;``


http://www.mrgr.cn/news/22528.html

相关文章:

  • Linux查找文件 find、locate、grep等使用说明
  • EmguCV学习笔记 VB.Net 11.3 DNN其它
  • Docker 部署 Nacos (图文并茂超详细)
  • SpringBoot项目是如何启动
  • 【NOI】C++算法入门之递归基础(数值类)
  • ssm鲜花销售微信小程序 LW PPT调试源码
  • 网上花店管理系统小程序的设计
  • C++第一节入门
  • JLabel设置字体大小颜色背景色
  • Go语言中实现安全高效的JWT认证:自定义中间件解析
  • nodejs 使用kafka案例,node-red配置kafka案例,从安装配置kafka开始
  • GraalVM的资料
  • 组件拆分综合案例——商城首页
  • 第T6周:好莱坞明星识别
  • 线性因子模型 - 独立分量分析(ICA)篇
  • Go语言现代web开发04 变量常量以及类型转换
  • 机器学习TFIDF的情感分类文章
  • 寻找身高相近的小朋友
  • 数据结构与算法03 顺序表+链表
  • 沁恒CH32在MounRiver Studio上环境配置以及使用详细教程