Mysql数据库系统库数据恢复

概述:

Mysql数据库自带系统数据库故障,恢复后业务数据不变

1 备份除系统库外其他库

bash 复制代码
# 1. 先获取所有数据库列表(排除 mysql、information_schema、performance_schema、sys)
mysql -u root -p -NBe "SHOW DATABASES WHERE \`Database\` NOT IN ('mysql', 'information_schema', 'performance_schema', 'sys')" > databases.txt
 
# 2. 用获取的数据库列表进行备份(排除系统库)
mysqldump -u root -p --databases $(cat databases.txt) > all_business_data.sql


-- 步骤说明:

第一条命令会生成一个仅包含业务数据库名称的文件 databases.txt(自动排除系统库)。

第二条命令通过 --databases 参数指定备份 databases.txt 中的所有业务库,实现 "排除 mysql 系统库" 的效果。

2 停止 MySQL 服务并备份当前数据目录

bash 复制代码
# 1. 停止MySQL服务
sudo systemctl stop mysqld

# 2. 备份当前数据目录(防止误操作,可选但推荐)
sudo mv /var/lib/mysql /var/lib/mysql_old_backup

3 创建新的空数据目录并初始化

  • 创建新的空数据目录
bash 复制代码
# 1. 创建新的数据目录
sudo mkdir /var/lib/mysql

# 2. 设置目录权限(必须为mysql用户)
sudo chown -R mysql:mysql /var/lib/mysql
sudo chmod -R 755 /var/lib/mysql
  • 初始化数据库
bash 复制代码
# 3. 初始化MySQL(生成全新的系统库,包括help_topic等表)
sudo mysqld --initialize --datadir=/var/lib/mysql --user=mysql
  • 获取初始化生成的临时 root 密码
bash 复制代码
sudo grep 'temporary password' /var/log/mysqld.log

4 启动 MySQL 并重置 root 密码

bash 复制代码
# 1. 启动MySQL服务
sudo systemctl start mysqld

# 2. 用临时密码登录
mysql -u root -p
# 输入步骤2中记录的临时密码

# 3. 修改root密码(替换为你的新密码)
ALTER USER 'root'@'localhost' IDENTIFIED BY 'new password';
FLUSH PRIVILEGES;

# 4. 退出MySQL
exit

5 恢复业务数据

bash 复制代码
# 恢复备份(输入新设置的root密码)
mysql -u root -p < all_business_data.sql

6 验证修复结果

bash 复制代码
# 1. 登录MySQL
mysql -u root -p

# 2. 检查系统表help_topic是否存在
USE mysql;
DESCRIBE help_topic;  # 正常显示表结构即修复成功

# 3. 检查业务数据是否恢复
USE 你的业务库名;
SHOW TABLES;  # 确认业务表已恢复
SELECT * FROM 你的业务表 LIMIT 1;  # 验证数据完整性

7 root用户开启远程连接

bash 复制代码
# 本地登录 MySQL(使用 root 账号)
mysql -u root -p
# 输入 root 密码后进入 MySQL 命令行

# 切换到 mysql 系统库(存储用户权限信息)
USE mysql;

-- 查询当前 root 用户的主机限制(默认是 localhost)
SELECT user, host FROM user WHERE user = 'root';

-- 修改 root 用户允许从所有 IP 连接
UPDATE user SET host = '%' WHERE user = 'root' AND host = 'localhost';

-- 刷新权限使修改生效
FLUSH PRIVILEGES;

相关推荐
kyriewen9 小时前
面试官让我查各部门工资最高的员工,我用AI三秒写出窗口函数,他愣了
后端·mysql·面试
小码工作室10 小时前
使用 HAVING 进行 MySQL 集合筛选
mysql
罗超驿10 小时前
18.事务的隔离性和隔离级别:MySQL面试高频考点全解析
数据库·mysql·面试
jran-10 小时前
Redis 命令
数据库·redis·缓存
小江的记录本11 小时前
【Java基础】Java 8-21新特性:JDK21 LTS:虚拟线程、模式匹配switch、结构化并发、序列集合(附《思维导图》+《面试高频考点清单》)
java·数据库·python·mysql·spring·面试·maven
June`11 小时前
多线程redis下如何解决aof重写和rdb持久化的数据一致性问题
数据库·redis·缓存
木心术111 小时前
Windows系统下MySQL与AI工具集成方案:数据存储与调用实践
人工智能·windows·mysql
二宝哥11 小时前
离线安装maven
java·数据库·maven
SZLSDH11 小时前
场景适配论 | 数字孪生IOC建设中渲染技术与智能体能力的协同逻辑
前端·数据库·ai·数字孪生·数据可视化·智能体
这个DBA有点耶11 小时前
SQL改写实战:子查询、CTE、窗口函数性能对比
数据库·mysql·性能优化