使用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
我們除了要備份了整個數(shù)據(jù)庫的dump以外,還需要備份relay-log.info文件(上例為mysql-relay-log.info),該文件包含類似如下信息:
/var/lib/mysql/mysql-relay-bin.000002
720
mysql-bin.0000023968
紅色高亮部分,指明了當(dāng)前MySQL主服務(wù)器上二進制日志的執(zhí)行狀態(tài)。這個數(shù)據(jù)在還原從服務(wù)器的時候至關(guān)重要。
使用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
在狀態(tài)中,如果有下面兩行,則表示從服務(wù)器工作正常:
Slave_IO_Running: Yes
Slave_SQL_Running: Yes
使用數(shù)據(jù)庫文件(Raw Data)進行備份和還原
備份數(shù)據(jù)庫文件
service mariadb stop
tar --selinux --acls --xattrs -czPf /root/dbbackup.tar.gz /var/lib/mysql/
service mariadb start
注意:紅色參數(shù)讓tar同時備份selinux屬性和其他ACL屬性,以防止還原到目標(biāo)服務(wù)器后無法使用。
還原數(shù)據(jù)庫文件
service mariadb stop
tar --selinux --acls --xattrs -xzPf /root/dbbackup.tar.gz -C /
service mariadb start
同時,還原數(shù)據(jù)文件的時候,也需要指定這些參數(shù)。
故障排查
錯誤消息
150401 9:58:06 [ERROR] mysqld: File '/var/lib/mysql/mysql-bin.index' not found (Errcode: 13)
150401 9:58:06 [ERROR] Aborting
檢查SeLinux設(shè)置
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),
修改完后需要重啟。
也可以在tar命令壓縮、解壓縮時添加如下參數(shù):
tar --selinux --acls --xattrs
您可能感興趣的文章:- MySQL用作備份還原的導(dǎo)入和導(dǎo)出命令用法整理
- 簡單的MySQL備份與還原方法分享
- MySQL使用命令備份和還原數(shù)據(jù)庫
- php實現(xiàn)MySQL數(shù)據(jù)庫備份與還原類實例
- MySQL筆記之?dāng)?shù)據(jù)備份與還原的使用詳解
- 自用mysql自帶命令實現(xiàn)數(shù)據(jù)庫備份還原的方法
- MySQL數(shù)據(jù)庫備份和還原的常用命令小結(jié)
- 淺談mysql 針對單張表的備份與還原