MySQL数据备份和还原的两种方法

2022-11-12 09:38:04
内容摘要
这篇文章主要为大家详细介绍了MySQL数据备份和还原的两种方法,具有一定的参考价值,可以用来参考一下。 对此感兴趣的朋友,看看idc笔记做的技术笔记! 使用mysqldump进行备份和
文章正文

这篇文章主要为大家详细介绍了MySQL数据备份和还原的两种方法,具有一定的参考价值,可以用来参考一下。

对此感兴趣的朋友,看看idc笔记做的技术笔记!

使用mysqldump进行备份和还原使用mysqldump进行备份

代码如下:


mysqladmin stop-slave -uroot -p
mysqldump --all-databases > fulldb.dump
mysqladmin start-slave -uroot -p
tar -czf /tmp/dbdump.tar.gz ./fulldb.dump ./mysql-relay-log.info

我们除了要备份了整个数据库的dump以外,还需要备份relay-log.info文件(上例为mysql-relay-log.info),该文件包含类似如下信息:

代码如下:


/var/lib/mysql/mysql-relay-bin.000002
720
mysql-bin.0000023968

红色高亮部分,指明了当前MySQL主服务器上二进制日志的执行状态。这个数据在还原从服务器的时候至关重要。使用mysqldump进行还原

代码如下:



mysql -uroot -p < /root/dbdump.db
stop slave;
CHANGE MASTER TO MASTER_HOST='192.168.10.201', MASTER_USER='slave_user', MASTER_PASSWORD='abc@DEF', MASTER_LOG_FILE='mysql-bin.000002', MASTER_LOG_POS=3968;
start slave;
show slave status\G

在状态中,如果有下面两行,则表示从服务器工作正常:

代码如下:



Slave_IO_Running: Yes
Slave_SQL_Running: Yes

使用数据库文件(Raw Data)进行备份和还原备份数据库文件

代码如下:



service mariadb stop
tar --selinux --acls --xattrs -czPf /root/dbbackup.tar.gz /var/lib/mysql/
service mariadb start

注意:红色参数让tar同时备份selinux属性和其他ACL属性,以防止还原到目标服务器后无法使用。还原数据库文件

代码如下:



service mariadb stop
tar --selinux --acls --xattrs -xzPf /root/dbbackup.tar.gz -C /
service mariadb start

同时,还原数据文件的时候,也需要指定这些参数。故障排查错误消息

代码如下:



150401 9:58:06 [ERROR] mysqld: File '/var/lib/mysql/mysql-bin.index' not found (Errcode: 13)
150401 9:58:06 [ERROR] Aborting

检查SeLinux设置

代码如下:



ll -Z mysql-bin.index
-rw-rw----. mysql mysql unconfined_u :o bject_r:var_lib_t:s0 mysql-bin.index

解决方法

可以禁用SeLinux(配置文件/etc/selinux/config),

代码如下:



SELINUX=disabled

修改完后需要重启。

也可以在tar命令压缩、解压缩时添加如下参数:

代码如下:



tar --selinux --acls --xattrs

注:关于MySQL数据备份和还原的两种方法的内容就先介绍到这里,更多相关文章的可以留意

代码注释

作者:喵哥笔记

IDC笔记

学的不仅是技术,更是梦想!