mysql ibdata1 还原数据库

当MySQL数据库因意外掉电导致无法启动时,可以通过备份的ibdata1和数据库目录进行恢复。步骤包括:备份data目录、删除并重新初始化data目录、启动MySQL、修改root密码、复制备份数据到新data目录下,特别是覆盖ibdata1文件,以恢复元数据。最后,确保文件权限正确以避免ERROR 1017。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

从mysql的data目录中恢复数据库

某台mysql数据库,突然掉电,重启系统启动数据库失败,进入数据库目录发现数据文件完好,从新初始化数据库,从数据文件中恢复数据

一、将/home/mysql-5.7.26/data/目录复制出来

[root@orderer home]# cd mysql-5.7.26/
[root@orderer mysql-5.7.26]# cp -R data/ ../data_bak

二、删除/home/mysql-5.7.26/data/目录,因为初始化数据库的时候,data目录必须为空

[root@orderer mysql-5.7.26]# rm -rf data/
[root@orderer mysql-5.7.26]# mkdir data

由于我是root账户操作的,所以将data目录权限赋予mysql用户

[root@orderer mysql-5.7.26]# chown -R mysql:mysql data

三、重新初始化数据库

[root@orderer home]# mysqld_safe --defaults-file=/etc/mysql/my.cnf --initialize --basedir=/home/mysql-5.7.26/ --datadir=/home/mysql-5.7.26/data/
2020-01-19T07:11:22.220590Z mysqld_safe Logging to '/home/mysql-5.7.26/log/mysqld.log'.
2020-01-19T07:11:22.266396Z mysqld_safe Starting mysqld daemon with databases from /home/mysql-5.7.26/data
2020-01-19T07:11:33.111853Z mysqld_safe mysqld from pid file /home/mysql-5.7.26/run/mysqld.pid ended

此时,查看data目录下已经生成了相关文件

[root@orderer mysql-5.7.26]# ll data ??? 110668 -rw-r----- 1 mysql mysql 56 1? 19 15:11 auto.cnf -rw------- 1 mysql mysql 1680 1? 19 15:11 ca-key.pem -rw-r--r-- 1 mysql mysql 1112 1? 19 15:11 ca.pem -rw-r--r-- 1 mysql mysql 1112 1? 19 15:11 client-cert.pem -rw------- 1 mysql mysql 1680 1? 19 15:11 client-key.pem -rw-r----- 1 mysql mysql 419 1? 19 15:11 ib_buffer_pool -rw-r----- 1 mysql mysql 12582912 1? 19 15:11 ibdata1 -rw-r----- 1 mysql mysql 50331648 1? 19 15:11 ib_logfile0 -rw-r----- 1 mysql mysql 50331648 1? 19 15:11 ib_logfile1 -rw-r----- 1 mysql mysql 177 1? 19 15:11 master-18-69.000001 -rw-r----- 1 mysql mysql 22 1? 19 15:11 master-18-69.index drwxr-x--- 2 mysql mysql 4096 1? 19 15:11 mysql drwxr-x--- 2 mysql mysql 8192 1? 19 15:11 performance_schema -rw------- 1 mysql mysql 1680 1? 19 15:11 private_key.pem -rw-r--r-- 1 mysql mysql 452 1? 19 15:11 public_key.pem -rw-r--r-- 1 mysql mysql 1112 1? 19 15:11 server-cert.pem -rw------- 1 mysql mysql 1676 1? 19 15:11 server-key.pem drwxr-x--- 2 mysql mysql 8192 1? 19 15:11 sys

 

查找mysql.log日志过滤"temporary password",得到系统生成的初始随机密码,第一次登陆使用

[root@orderer mysql-5.7.26]# cat /home/mysql-5.7.26/log/mysqld.log|grep 'temporary password'
2020-01-19T07:11:25.453456Z 1 [Note] A temporary password is generated for root@localhost: PcrY;58llX3<

四、启动mysql

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值