备份与还原MySQL从服务器步骤

今天Lesca将介绍如何备份和还原MySQL的从服务器,平台仍然是CentOS 7。
使用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.000002
3968

红色高亮部分,指明了当前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:object_r:var_lib_t:s0 mysql-bin.index

解决方法

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

修改完后需要重启。

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

拓展知识

–selinux – Save the SELinux context to the archive
–acls – Save the ACLs to the archive
–xattrs – Save the user/root xattrs to the archive. It archives all extended attributes, including SELinux and ACLs.

时间: 2024-10-25 00:58:52

备份与还原MySQL从服务器步骤的相关文章

php简单备份与还原MySql的方法_php技巧

本文实例讲述了php简单备份与还原MySql的方法.分享给大家供大家参考,具体如下: 一.备份: <?php header ( "content-Type: text/html; charset=utf-8" ); //备份数据库 $host="localhost"; $user="root";//数据库账号 $password="123456";//数据库密码 $dbname="test";//数据

命令行模式下备份、还原 MySQL 数据库的语句小结_Mysql

为了安全起见,需要经常对数据库作备份,或者还原.对于 MySQL 而言,最方便的方法可能就是用 phpMyAdmin 的导出.导入功能了,但如果你的数据库体积比较大,作为 Web 应用的 phpMyAdmin 可能会遭遇"超时"而操作失败.所以,学会在命令行模式下备份.还原数据库,还是很有必要的. 1.备份数据库 在 Linux 命令行模式下备份 MySQL 数据库,用的是 mysqldump 命令: 复制代码 代码如下: mysqldump -u mysqluser -p test_

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

使用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数据的两种方法

使用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文件(上例

利用Navicat for MySQL工具备份、还原MySQL数据库

我们常规的备份还原网站数据库会采用直接phpMyAdmin导出和导入,或者较为推荐的采用mysqldump命令模式.这不在之前几天看到有网友讨论使用Navicat for MySQL工具进行备份和还原数据库,看到这个工具的信息量还是蛮大的,应该还算用的比较多.   Navicat for MySQL工具的好处就是可视化,我们可以直接在软件界面中进行备份.还原.查询管理等,甚至可以设置定时备份任务.因为老左之前还不认识这个软件,所以更谈不上使用经验,对于基本的备份还原数据库,以及界面的认识,我准备

mysqldump备份与还原mysql数据库

mysql 数据备份和恢复我们可以使用myql自带的工具 mysqldump .mysql‍ 来实现. mysqldump 支持 远程单表备份.单数据库备份.所有数据库备份. ‍==备份== 注意空格‍,额外参数请自行添加.如 -h -u -p ,远程备份需要指定 -h 服务器地址 -e 表示导出sql为批量插入比普通插入快20倍以上 -h 服务器主机地址 -u 帐号 -p 帐号密码 单表备份( 备份一个表 )  代码如下 复制代码 mysqldump -e -u xxx -pxxx 数据库名称

MySQL使用命令备份和还原数据库_Mysql

数据库在使用当中都会有数据库备份工作,当数据库发生严重错误无法启动,或者数据丢失时可以及时有效地恢复数据.文章简单介绍如何备份和还原MySQL数据库. 备份数据库 使用mysqldump命令备份数据库 复制代码 代码如下: # 如果要将game数据库进行备份: mysqldump -u root -p game > game_backup.sql # 如果希望备份所有的数据库: mysqldump -u root -p --all-databases > all_backup.sql 还原数据

mysql-c# 怎么备份和还原腾讯云的MYSQL数据库呢

问题描述 c# 怎么备份和还原腾讯云的MYSQL数据库呢 我在腾讯云买了个数据库,之前获得6块钱,里面有些数据,但是我不知道数据存储的地址,有什么办法备份和还原吗? 解决方案 C# Tip -- C#实现MySQL数据库的备份和还原备份与还原mysql数据库Java备份还原Mysql数据库

MySQL的备份与还原

原文:MySQL的备份与还原 MySQL备份和还原,都是利用mysqldump.mysql和source命令来完成的. 1.Win32下MySQL的备份与还原 1.1 备份 开始菜单 | 运行 | cmd |利用"cd /Program Files/MySQL/MySQL Server 5.0/bin"命令进入bin文件夹 | 利用"mysqldump  -u 用户名 -p databasename >exportfilename"导出数据库到文件,如mysq