介绍备份和还原MySQL数据的两种方法
程序员文章站
2023-11-25 15:13:10
使用mysqldump进行备份和还原
使用mysqldump进行备份
mysqladmin stop-slave -uroot -p
mysqldump --...
使用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