设为首页 收藏本站
查看: 861|回复: 0

[经验分享] mysql备份计划

[复制链接]

尚未签到

发表于 2018-10-10 07:57:22 | 显示全部楼层 |阅读模式
  MYSQL完全与增量备份
  文档介绍
  本文档采用mysqldump 对数据库进行备份,mysqldump 是采用SQL级别的备份机制,它将数据表导成 SQL 脚本文件,在不同的 MySQL 版本之间升级时相对比较合适,这也是最常用的备份方法,mysqldump 比直接拷贝要慢些。
  本文描述Mysql数据库的自动备份,包括完全备份和增量备份。其中,完全备份每周六执行一次,系统自动保存最近一个月的备份文件,增量备份每天都会执行,系统自动保存最近35天的备份文件。
  备份策略布置
  (1)、创建备份目录与文件
  Shell> mkdir /srv/bakmysql
  Shell> mkdir /srv/bakmysql/daily
  Shell> touch /srv/bakmysql/mysqlbak.log
  Shell>
  (2)、启用二进制日志
  采用 binlog 的方法相对来说更灵活,省心省力,而且还可以支持增量备份。
  启用 binlog 时必须要重启 mysqld。首先,关闭 mysqld,打开 /etc/my.cnf,加入以下几行:
  [mysqld]
  log-bin
  然后启动 mysqld 就可以了。运行过程中会产生 HOSTNAME-bin.000001 以及 HOSTNAME-bin.index,前面的文件是 mysqld 记录所有对数据的更新操作,后面的文件则是所有 binlog 的索引,都不能轻易删除。关于 binlog 的更详细信息请查看手册。
  (3)、设置crontab任务,每天执行备份脚本
  shell> vi /etc/crontab
  添加以下:
  #每个星期六凌晨1:00执行完全备份脚本
  0 1 * * 6 root /usr/sbin/mysqlfullbak
  #每天凌晨6:00做增量备份
  0 6 * * *root /usr/sbin/mysqldailybak
  (4)、使用SSH将mysqldailybak mysqlfullbak rmbackup三个文本内容放到系统/usr/sbin目录下相应的文件中,并且添加可执行权限,如:chmod +x rmbackup
  脚本内容
  完全备份脚本
  #!/bin/bash
  # Name:mysqlfullbak
  # This is mysql mysqlfullbak scripts
  # By song
  # Last Modify:2011-02-23
  #定义脚本存放路径
  scriptsDir=/usr/sbin
  #定义用户名及密码
  user=root
  userPWD=123456789
  #定义要备份的数据库
  database=castor
  #定义完全备份文件存放路径
  bakDir=/srv/bakmysql
  eMailFile=$bakDir/email.txt
  eMail=sdesong@163.com
  #定义日志文件
  LogFile=$bakDir/mysqlbak.log
  DATE=`date +%Y%m%d`
  echo " " >> $LogFile
  echo " " >> $LogFile
  echo "--------------------------" >> $LogFile
  echo $(date +"%y-%m-%d %H:%M:%S") >>$LogFile
  echo "-----------------" >> $LogFile
  cd $bakDir
  DumpFile=$DATE.sql
  #GZDumpFile=$DATE.sql.tgz
  mysqldump --flush-logs -u$user -p$userPWD --quick $database >$DumpFile
  echo "Dump Done" >> $LogFile
  #tar cvzf $GZDumpFile $DumpFile >> $LogFile 2 >2&1
  #echo "[$GZDumpFile]Backup Success!" >> $LogFile
  echo  "[$DumpFile]Backup Success!" >> $LogFile
  #Delete old backup files(mtime>2)
  $scriptsDir/rmbackup
  #Delete previous daily backup files:完整备份后,删除增量备份的文件,只保留最近35天的增量备份文件
  daily_databakDir=$bakDir/daily
  cd $bakDir/daily
  find $daily_databakDir -name
  "daily*" -type f -mtime +35 -exec rm {} \; > /dev/null 2>&1
  #发送邮件通知
  #cat $eMailFile | mail -s "MySQL Backup" $eMail
  增量备份脚本
  #!/bin/bash
  # Name:mysqldailybak
  # This ia mysql mysqldailybak scripts
  # By songdesong
  # Last modify:2011-02-23
  #定义用户名及密码
  user=root
  userPWD=123456789
  #定义数据库
  database=castor
  /usr/bin/mysqladmin -u$user -p$userPWD flush-logs
  daily_databakDir=/srv/bakmysql/daily
  #定义MYSQL数据目录
  mysqlDataDir=/srv/mysql/
  eMailFile=$daily_databakDir/email.txt
  eMail=sdesong@163.com
  DATE=`date +%Y%m%d`
  logFile=$daily_databakDir/mysql$DATE.log
  echo "       " > $eMailFile
  echo "-----------------------" >> $eMailFile
  echo $(date +"%y-%m-%d %H:%M:%S") >> $eMailFile
  echo "-------
  ------------------" >> $eMailFile
  TIME=$(date "-d 10 day ago" +%Y%m%d%H%M%S)
  StartTime=$(date "-d 1 day ago" +"%Y-%m-%d %H:%M:%S")
  echo “Delete 10 days before the log” >>$eMailFile
  mysql -u$user -p$userPWD -e "purge master logs before ${TIME}" && echo "delete 10 days before log" |tee -a $eMailFile #删除10天前的2进制文件
  filename=`cat $mysqlDataDir/mysqld-bin.index |awk -F "/" '{print $2}'` # 2进制文件
  for i in $filename
  do
  echo "$StartTime start backup binlog" >> $eMailFile
  mysqlbinlog -u$user -p$userPWD -d $database --start-datetime="$StartTime" $mysqlDataDir/$i >> $daily_databakDir/daily$DATE.sql |tee -a $eMailFile
  done
  if [ $? = 0 ]
  then
  # 删除mtime>32的增量日志备份文件
  find $daily_databakDir -name "*.log" -type f -mtime +32 -exec rm {} \; > /dev/null 2>&1
  cd $daily_databakDir
  #tar -cvzf $daily_databakDir/$database$DATE.tar.gz daily$DATE.sql >>/dev/null 2&1
  #scp 至另一台服务器
  echo "Daily backup succeed" >> $eMailFile
  else
  echo "Daily backup fail" >> $eMailFile
  mail -s "MySQL Backup" $eMail < $eMailFile #备份失败之后发送邮件通知
  fi
  cat $eMailFile > $logFile
  # 删除mtime>32的增量日志备份文件
  find $daily_databakDir -name "*.log" -type f -mtime +32 -exec rm {} \; > /dev/null 2>&1
  删除完全备份文件脚本
  #!/bin/sh
  # Name:rmBackup
  # PS:Delete old Backup.
  # By:song
  # Last Modify:2011-02-17
  #
  # 定义备份目录
  dataBackupDir=/srv/bakmysql
  # 删除mtime>32的日志备份文件
  find $dataBackupDir -name "*.sql" -type f -mtime +32 -exec rm {} \; > /dev/null 2>&1
  数据库恢复
  完全备份文件的恢复
  完全备份文件的格式为:20110301.sql
  登录MYSQL(mysql –uroot –p123456789)
  use castor;
  source  /home/20110301.sql
  增量备份文件的恢复
  增量备份文件的格式为:daily20110302.sql
  use castor;
  source /home/ daily20110302.sql


运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-619720-1-1.html 上篇帖子: 停止Azure MySQL PaaS数据库 下篇帖子: 生产环境MySQL快速备份工具XtraBackup使用案例
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表