程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> SqlServer數據庫 >> 關於SqlServer >> 介紹備份和還原MySQL數據的兩種方法

介紹備份和還原MySQL數據的兩種方法

編輯:關於SqlServer

使用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

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved