mysql备份策略
2024-08-31 21:30:26
1.备份的种类
- 完全备份,就是备份整个数据库对象
- 事务日志备份, 备份事务日志记录上一次的数据库改变
- 增量备份,也叫差异备份
- 文件备份
2.备份方式
- 逻辑备份, 既备份sql语句,使用mysql自带的mysqldump工具进行备份。备份成sql文件形式
- 物理备份, 备份数据库文件
两种备份方式的比较:参考MYSQL自动备份策略的选择与实践
3.备份工具
1.mysqldump
mysqldump是mysql自带的备份工具,属于逻辑备份支持innodb的热备份
,备份速度慢,适用于备份数据量小的场景。
对myisam存储引擎的表,只能使用温备份,这个时候要防止数据的写入,所以先加上读锁, --lock-all-tables
mysqldump --databases test --lock-all-tables --flush-logs > /tmp/backup_test_`date+%F-%H-%M`.sql
innodb存储引擎表,可以热备,不必对数据库进行加锁的操作,加一个选项可以进行热备份,--single-transaction
mysqldump --databases test --single-transaction --flush-logs--master-data=2> /tmp/backup_test_`date +%F-%H-%M`.sql
更多mysqldump命令,参考MySQL备份命令mysqldump参数说明与示例
2.基于LVM快照备份
物理备份方式
- 基于文件系统的物理备份(LVM的快照)
- tar之类的命令对整个数据库目录进行打包备份
备份的流程都是遵循以下:
- 开启窗口1,临时锁所有表, mysql> flush tables with read lock; 可以在mysql中使用 show master status; 查看状态, 注意这个窗口不能关闭,直到所有备份完成之后才能关闭
- 开启窗口2,tar备份数据库文件, tar -zcvf mysqla1.tar.gz mydata
- 备份完成,切换窗口1进行解锁, mysql> unlocktables;
4.个人方案
每晚凌晨3点mysqldump备份数据库
#加入定时计划
* 03 * * * /root/mytools/mysqlback.sh
脚本如下:
DB_NAME="res"
DB_USER="root"
DB_PASS="****"
BIN_DIR="/usr/bin/" # mysqldump命令所在路径
BACK_DIR="/data/backdata" # 备份工具的路径
DATE="mysql-`date +'%Y%m%d-%H:%M:%S'`"
LogFile="$BACK_DIR"/dbbakup.log # 日志记录保存的目录
BackNewFile=$DATE.sql
$BIN_DIR/mysqldump --opt --force -u$DB_USER -p$DB_PASS $DB_NAME > $BACK_DIR/$DATE.sql
echo -----------------------"$(date +"%y-%m-%d %H:%M:%S")"----------------------- >> $LogFile
echo createFile:"$BackNewFile" >> $LogFile
#-ctime表示创建时间,这里表示删除创建时间为多少天之前的文件,也就是结果只保留多少天的数据
find "/data/backdata/" -ctime +7 -type f -name "*.sql" -print > deleted.txt
echo -e "delete files:\n" >> $LogFile
#循环删除匹配到的文件
cat deleted.txt | while read LINE
do
rm -rf $LINE
echo $LINE>> $LogFile
done
echo "---------------------------------------------------------------" >> $LogFile
最新文章
- Xamarin.Android广播接收器与绑定服务
- ORACLE判别字段是否包含中文
- Qt里获取目录的一个另类方法
- Velocity(2)——引用
- 【JQuery NoviceToNinja系列】01 开篇 Html页面设计和布局
- ORACLE 修改日志大小及增加日志成员
- VMwave下Ubuntu扩展磁盘空间
- 偶然发现www.ghostdogtattoo.com/ 出现的inner.html转换现象
- 使用git工具快速push项目到github(精简)
- 潭州课堂25班:Ph201805201 WEB 之 CSS 第三课 (课堂笔记)
- poj3253哈夫曼树
- python中pip
- nginx反向代理和tomcat集群(适用于ubutnu16.04及其centos7)
- 【API】遍历进程的几种方式
- 对多维向量vector<;vector<;int>; >; vec进行操作
- bzoj1819 电子词典
- HTML文档的经常使用标记
- POJ2195:Going Home(费用流入门)
- JavaWeb—Tomcat
- [Postgres]合并多行到一列(转)