菜鸟学Linux 第078篇笔记 mysql 备份mysqldump
内容总览
备份类型、备份类型详解
备份工具
mysqldump实现备份还原
MySQL的备份和还原
备份:副本
RAID1,RAID10 保证硬件损坏而不会影响业务中止
备份类型
热备份、温备份、冷备份
热备份:读、写不受影响
温备份:仅可执行读操作
冷备份:离线备份 读、写操作均中止
物理备份、逻辑备份
物理备份:直接复制数据文件
逻辑备份:将数据导出至文本文件中
完全备份、增量备份和差异备份
完全备份:备份全部数据
增量备份:仅备份上次完全备份或增量备份以后变化的数据
差异备份:仅备份上次完全备份以来变化的数据
增量和差异区别:增量是每次备份是比较与前一次的区别并进行备份
差异是与第一次完全备份作比较,并将有差异的备份
(差异相对浪费硬盘空间一些,易于管理)
备份可自由根据需求来组合
在线物理完全备份
在线逻辑增量备份...
热备份(技术复杂度最高)
MyISAM lvm 热备 温备
InnoDB 支持热备 xtrabackup, mysqldump
冷备 mysql --> 从
物理备份 速度快,移植性不是特别好
逻辑备份 速度慢,会丢失浮点数精度,
方便使用文本处理工具直接对其处理,可移植能力强
备份策略: 完全+增量;完全+差异
数据变量的频度,和变化量
可以忍受的还原时长
备份的东东
数据、配置文件、二进制日志、事务日志
还原 测试,预演,多人分工,还原紧急处理方案
MySQL备份工具:
mysqldump 逻辑备份工具 冷备 MyISAM(温) InnoDB(热)
mysqlhostcopy 物理备份工具 温备份
文件系统工具
cp 冷备
lv 逻辑卷的快照功能,几乎热备
mysql> FLUSH TABLES;
mysql> LOCK TABLES;
创建快照:释放锁,而后复制数据即可
InnoDB:
第三组工具:
ibbackup (InnoDB) 商业工具
xtrabackup 开源工具
mysqldump 逻辑备份
mysqldump (完全备份) + 二进制日志
完全+增量
mysqldump DB_NAME [tb1] [tb2]
--master-data={0|1|2}
0 不记录二进制日志文件及其事件位置
1 以CHANGE MASTER TO方式记录位置,可用于恢复后直接启动从服务器
2 以CHANGE MASTER TO的方式记录位置,但默认被注释
--lock-all-tables 锁定所有表
--flush-logs 执行日志flush
如果指定库中的表类型均为InnoDB,可使用--single-transaction启动热备
(不要和--lock-all-tables一起使用)
--events
--routines
--triggers
备份多个库
--all-databases 备份所有库
--databases DB_NAME1,DB_NAME2 备份指定库
(使用此种备份,恢复时则不需要自己手动新建数据库名)
实验备份和还原
备份策略: 每周完全+每日增量
完全备份:mysqldump
增量备份:备份二进制日志文件(flush logs)
1.备份数据库
完全备份(备份文件要放在其它硬盘这里做测试所以只是放在其它目录里了)
# mysqldump -uroot -p --master-data=2 --flush-logs --all-databases \
--lock-all-tables > /root/all-dbs.sql
(此为一行命令)
mysql> PURGE BINARY LOGS TO 'mysql-bin.000007'; (不建议删除,只是为了做测试)
可以备份后再删除掉
做增量备份(第二天)
mysql> FLUSH LOGS;
将滚动后的日志备份(直接复制即可) 前边的目录是二进制日志所放目录
cp /mydata/data/mysql-bin.000007 /root/binary-`date +%Y-%m-%d`.sql
mysqlbinlog /mydata/data/mysql-bin.000007 > /root/monday-incremental.sql
(推荐此上条备份二进制日志文件)
第三天做增量和此一样 模拟此天不小心把数据库给删除了
(但是造成不要把二进制日志删除了哈,,这要没了就挂了)
先将二进制文件复制出来
cp /mydata/data/mysql-bin.000008 > /root/mysql-bin.000008.sql
# rm -rf /mydata/data/* (模拟数据库损坏)
还原数据库
由于我模拟的太暴力直接把库文件也给删除了所以需要重新初始化数据库
# killall mysqld
初始化数据库
# ./scripts/mysql_install_db --user=mysql --datadir=/mydata/data
还原完全备份
# mysql -uroot -p < /root/all-dbs.sql
导入增量备份
# mysql -uroot -p < /root/monday-incremental.sql (使用的是mysqlbinlog)
最后一步把最后一次的二进制日志导入到数据库
# mysqlbinlog mysql-bin.000008.sql | mysql -uroot -p
(到此步便为即时点还原)
mysqldump虽然可以实现备份还原,但是会丢失精度,只适合小型的数据库
最后作业
脚本完成完全备份
脚本完成增量备份
并添加至任务计划让其自动执行备份
(目前个人未做出来)