跳过mysql8.0密码重置密码 Shell脚本

要在 MySQL 8.0 中通过 Shell 脚本跳过密码验证以重置密码,你可以遵循以下步骤:首先,确保你有足够的权限来编辑配置文件和重启 MySQL 服务。下面是一个简单的 Shell 脚本示例,该脚本展示了如何跳过密码验证以重置 MySQL 8.0 的 root 用户密码:

复制代码
#!/bin/bash

# 停止 MySQL 服务
sudo systemctl stop mysqld

# 跳过密码验证启动 MySQL
sudo mysqld_safe --skip-grant-tables &

# 等待 MySQL 服务启动
sleep 5

# 登录 MySQL,不需要密码
mysql -u root <<EOF
USE mysql;
ALTER USER 'root'@'localhost' IDENTIFIED BY 'your_new_password';
FLUSH PRIVILEGES;
exit;
EOF

# 停止 mysqld_safe 进程
sudo killall mysqld_safe

# 等待 MySQL 服务停止
sleep 2

# 启动 MySQL 服务
sudo systemctl start mysqld

# 输出成功信息
echo "MySQL root password has been reset successfully!"

在这个脚本中,请将 'your_new_password' 替换为你想要设置的新密码。脚本执行以下操作:

停止 MySQL 服务。

使用 mysqld_safe 启动 MySQL,并跳过权限检查。

使用 sleep 命令等待 MySQL 服务启动。

通过重定向输入的方式登录 MySQL,并执行 SQL 命令来更改 root 用户的密码。

停止 mysqld_safe 进程。

使用 sleep 命令等待 MySQL 服务停止。

重启 MySQL 服务。

输出成功信息。

要运行这个脚本,请将其保存到一个文件中,例如 reset_mysql_password.sh,然后在终端中运行以下命令来执行脚本:

复制代码
chmod +x reset_mysql_password.sh
./reset_mysql_password.sh

请确保你具有执行这个脚本的权限,并且你的用户账户有权限停止和启动 MySQL 服务。

注意:在生产环境中,跳过密码验证来重置密码是一个敏感的操作,因为它会暂时暴露你的数据库不受密码保护。确保在执行此操作之前备份所有重要数据,并在操作完成后尽快恢复正常的权限检查。

相关推荐
@杰克成2 天前
Java学习31
java·学习·adb
萑澈3 天前
如何在Rocky Linux 8单节点集群上安装Apache Hadoop
adb
禁默4 天前
解密 LangChain:LLM 应用开发的核心框架与“超级武器”
android·adb·langchain·vibe coding
Waay5 天前
MySQL基础高频考点
运维·mysql·adb
蜀道山老天师6 天前
从零搭建 Prometheus 监控 MySQL:含二进制安装、授权、exporter 配置全流程
运维·数据库·mysql·adb·云原生·prometheus
qq_297574677 天前
MySQL核心技术实战系列(第一篇):MySQL零基础入门:安装、配置与客户端工具使用 一、前言
数据库·mysql·adb
Languorous.7 天前
MySQL 零基础安装教程(Windows11/10,图文分步,新手零失败)
数据库·mysql·adb
huaiixinsi7 天前
Canal + Outbox、Kafka 选型与高可用、Caffeine 底层原理总结
java·数据库·分布式·mysql·spring·adb·kafka
Languorous.7 天前
MySQL 登录报错排查:1045、2003 错误,新手快速解决
数据库·mysql·adb
shaoming37767 天前
浏览器动作开发:地址栏图标点击事件、弹出页面设计
android·mysql·adb