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

[经验分享] mysql异机定时备份

[复制链接]

尚未签到

发表于 2018-10-4 06:40:32 | 显示全部楼层 |阅读模式
  MYSQL定期备份是一项重要的工作,但人工操作太繁琐,也难避免有所疏漏,本文主要讲述利用crontab定时备份mysql至本机,以及利用rsync同步数据到异机,从而达到异机定时备份。
  mysql定时备份篇
  1、创建备份文件夹
  #mkdir -p /u01/bak/mysqldata
  2、编写运行脚本
  #vim /usr/sbin/bakmysql.sh
  代码:
  #!/bin/bash
  # Name:bakmysql.sh
  # This is a ShellScript For Auto DB Backup and Delete old Backup
  #
  backupdir=/u01/bak/mysqldata
  time=` date +%Y%m%d%H `
  /usr/bin/mysqldump -u root -ppassword dataname  > $backupdir/name1$time.sql
  /usr/bin/mysqldump -u root -ppassword dataname  > $backupdir/name2$time.sql
  /usr/bin/mysqldump -u root -ppassword dataname > $backupdir/name3$time.sql
  #
  find $backupdir -name "*.sql" -type f -mtime +5 -exec rm {} \; > /dev/null 2>&1
  注:删除5天前备份文件
  3、为脚本添加执行权限
  # chmod +x /usr/sbin/bakmysql.sh
  4、修改/etc/crontab
  58 23 * * * root /usr/sbin/bakmysql.sh
  注:每晚23:58执行一次自动备份
  5、重启crontab
  # /etc/rc.d/init.d/crond restart
  6、恢复数据备份文件
  #mysql -u root -p dataname < name2008010103.sql
  异机同步篇(使用rsync算法)
  1、配置hosts(主机、备机)
  #vim /etc/hosts
  IP1     hostname1
  IP2     hostname2
  2、安装rsync(主机、备机)
  #yum install rsync
  3、 配置rsync服务器
  #vim /etc/rsyncd.conf
  uid = root
  gid = root
  max connections = 200
  timeout = 600
  use chroot = no
  read only = no
  port = 873
  log file=/var/log/rsyncd.log
  pid file=/var/run/rsyncd.pid
  lock file=/var/run/rsyncd.lock
  [test]
  path=/u01/bak/mysqldata
  comment=backup test
  ignore errors
  hosts allow=IP2
  auth user=test
  secrets file=/root/rsync.passwd
  #vim /root/rsync.passwd
  test 123456
  #chown root:root /root/rsync.passwd
  #chmod 600 /root/rsync.passwd
  4、 配置rsync客户端
  #vim /etc/rsyncd.conf
  uid = root
  gid = root
  max connections = 200
  timeout = 600
  use chroot = no
  read only = no
  port = 873
  log file=/var/log/rsyncd.log
  pid file=/var/run/rsyncd.pid
  lock file=/var/run/rsyncd.lock
  [test]
  path=/home
  comment=backup test
  ignore errors
  hosts allow=IP1
  auth user=test
  secrets file=/root/rsync.passwd
  #vim /root/rsync.passwd
  123456
  #chown root:root/root/rsync.passwd
  #chmod 600 /root/rsync.passwd
  5、启动rsync服务(主机、备机)
  #/usr/bin/rsync --daemon
  #netstat -an | grep 873
  注:开机启动如下
  #vim /etc/rc.d/rc.local
  /usr/bin/rsync --daemon
  6、编写定时同步脚本
  #vim /etc/rsync.sh
  代码:
  #!/bin/bash
  #Name:rsync.sh
  #This is a ShellScript For Data synchronization
  rsync -vrtopg --progress --delete root@IP1::test/ /home --password-file=/root/rsync.passwd
  7、设置定时执行
  #chmod +x /etc/rsync.sh
  #vim /etc/crontab
  58 23 * * * root /etc/rsync.sh
  8、重启crontab
  # /etc/rc.d/init.d/crond restart
  至此mysql异机定时备份完成,建议一周内须查看备份效果,以及测试mysql备份可用性。
  扩展阅读(网络参考资料,以下资料归属网络作者,请注重“版权”):
  http://www.howtocn.org/rsync:use_rsync_server                          使用 rsync 服务
  http://colderboy.blog.51cto.com/485582/132054/                         rsync参数详解、利用ssh、rsync 实现数据的定时同步


运维网声明 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-611591-1-1.html 上篇帖子: mysql CHAR_LENGTH()与LENGTH() 下篇帖子: MysqlReport 监控mysql
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

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

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

扫描微信二维码查看详情

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


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


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


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



合作伙伴: 青云cloud

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