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

ops/2024/9/23 23:35:38/

目录

  • 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.ppmy.cn/ops/110502.html

相关文章

JAVAWeb-Servlet

一 Servlet简介 1.1 动态资源和静态资源 静态资源 无需在程序运行时通过代码运行生成的资源,在程序运行之前就写好的资源. 例如:html css js img ,音频文件和视频文件 动态资源 需要在程序运行时通过代码运行生成的资源,在程序运行之前无法确定的数据,运行时动态生成,例如Ser…

JS面试真题 part5

JS面试真题 part5 21、说说对事件循环的理解22、JavaScript本地存储方式有哪些&#xff1f;区别及应用场景&#xff1f;23、大文件上传如何断点续传&#xff1f;24、ajax原理是什么&#xff1f;如何实现&#xff1f;25、什么是防抖和节流&#xff1f;有什么区别&#xff1f;如何…

Linux下抓包分析Java应用程序HTTP接口调用:基于tcpdump与Wireshark的综合示例

Java应用程序常通过HTTP与外部系统交互&#xff0c;在复杂的应用场景下&#xff0c;了解Java应用程序在运行期间调用了哪些HTTP接口&#xff0c;以及请求与响应的具体参数&#xff0c;对开发调试、运维监控至关重要。本文将详细介绍如何通过Linux下的tcpdump抓包&#xff0c;并…

openharmony-界面适配

1. 像素单位 参考&#xff1a;像素单位-公共定义-ArkTS组件-ArkUI&#xff08;方舟UI框架&#xff09;-应用框架 - 华为HarmonyOS开发者 (huawei.com) 鸿蒙方舟框架为开发者提供了4种像素单位&#xff0c;即&#xff1a;px、vp、fp、lpx。并且框架采用vp为基准数据单位。类似…

Spring Boot基础

项目创建 项目启动 请求响应 RestController 1.返回值处理 RestController&#xff1a;这个注解结合了Controller和ResponseBody的功能。它默认将所有处理请求的方法的返回值直接作为响应体内容返回&#xff0c;主要用于构建RESTful API。返回的数据格式通常是JSON或XML&…

鸡肉品质分级与分类系统源码分享

鸡肉品质分级与分类检测系统源码分享 [一条龙教学YOLOV8标注好的数据集一键训练_70全套改进创新点发刊_Web前端展示] 1.研究背景与意义 项目参考AAAI Association for the Advancement of Artificial Intelligence 项目来源AACV Association for the Advancement of Comput…

Java数据结构应用(力扣题20. 有效的括号)

给定一个只包括 (&#xff0c;)&#xff0c;{&#xff0c;}&#xff0c;[&#xff0c;] 的字符串 s &#xff0c;判断字符串是否有效。 有效字符串需满足&#xff1a; 左括号必须用相同类型的右括号闭合。左括号必须以正确的顺序闭合。每个右括号都有一个对应的相同类型的左括…

NIO详细解释

Java NIO 详解 Java NIO&#xff08;New Input/Output&#xff09;是Java 1.4引入的用于替代传统I/O&#xff08;Java I/O&#xff09;的一种新型I/O处理方式。NIO的目标是解决传统阻塞式I/O模型的性能瓶颈&#xff0c;提供更高效的I/O操作&#xff0c;特别是适用于需要高并发…