自定义脚本工具自动化备份云服务器数据库方法

  时至年终我们很多公司已经陆续开始放假,但是作为运维人员肯定时刻需要关注公司负责客户的网站和项目的运行情况,一来我们使用监控服务器的稳定性情况,同时前几天老 左也有检查一遍所负责的客户服务器和域名是否有在春节期间到期需要续费的都提前续费。一般在过年期间网站的更新数据不大,于是统一都做好镜像备份和本地数据备份。

  一般网站的文件是很少变动的,除非是修改模板数据,静态文件也都分离至第三方存储所以安全性相对比较高,最为主要的就是数据库,如果我们有的客户使用的是云数据库都开启自动备份所以这一块我也不去管,其他的数据库如果有客户使用的WEB面板自带备份功能我都给推送到第三方存储备份数据库,其他的我可以使用脚本来自定义备份后同步上传到备份服务器。

数据库备份脚本

#!/bin/bash
tool=/usr/bin/mysqldump
dd=`date +%Y%m%d`
username=root #数据库用户名
password=laozuo.org #数据库密码
database=laozuo #数据库名
backup_count=2
backup_dir=~/mysqlbackup #备份数据库目录
# 创建备份目录
mkdir -p $backup_dir
#创建备份 mysqldump -u root -p123456 users > /root/mysqlbackup/users-$filename.sql
$tool -u $username -p$password $database > $backup_dir/$database-$dd.sql
#写备份日志
echo "create $backup_dir/$database-$dd.sql" >> $backup_dir/action.log
#找出需要删除的备份
delfile=`ls -l -crt $backup_dir/*.sql | awk '{print $9 }' | head -1`
#判断现在的备份数量是否大于$backup_count
count=`ls -l -crt $backup_dir/*.sql | awk '{print $9 }' | wc -l`
if [ $count -gt $backup_count ] then
rm $delfile #删除最早生成的备份,只保留backup_count数量的备份
#写删除文件日志
echo "delete $delfile" >> $backup_dir/action.log
fi

这个文件我们可以设定命名backupdata.sh,且需要修改成自己的数据库参数。

执行备份效果

我们可以直接自己丢到对应目录中先执行脚本看看是否可以生效,如果能备份到,那我们说明这个脚本有效。

设置定时备份规则

0 0 * * * /backup/backupdata.sh > /dev/null 2>&1 &

我们可以添加定时规则,设置在凌晨备份。当然我们如果是数据更新不大,那就不要备份。比如我们公司大部分是企业网站的话过年期间也没人更新,所以我就在这几天都给备份过,年后再说吧,即便有问题我本地也有备份可以恢复。

历史上的今天

2020年:给网站底部注入网站已稳定运行xx天及页面加载时间(0条评论)

2020年:解决VNC Viewer报错inflate failed with error-3(0条评论)

2015年:批处理实现SQLServer数据库备份与还原(0条评论)

本文来源 https://www.laozuo.org/15494.html,经授权后发布,本文观点不代表 Mr.xu 博客网 立场,转载请联系原作者。

发表评论

登录后才能评论

此站点使用Akismet来减少垃圾评论。了解我们如何处理您的评论数据

线上沟通

笔者期待与您共勉 · 互赢

有言必答:点击这里给我发消息

商务洽谈:交互沟通 · 共赢互利

邮件:admin@xuxiaokun.com

线上沟通:周一至周五 9:30 - 17:30

其余时间Mail或QQ我,有言必应。

微信关注
微信关注
投递稿件 我要留言
分享本页
返回顶部