【题目要求】

设计一个shell脚本用来备份数据库,首先在本地服务器上保存一份数据,然后再远程拷贝一份,本地保存一周的数据,远程保存一个月

SRE实战 互联网时代守护先锋,助力企业售后服务体系运筹帷幄!一键直达领取阿里云限量特价优惠。

假设我们知道mysql root账号的密码,要备份的库为data123,本地备份目录为/bak/mysql,远程服务器ip为192.168.1.100,远程提供了一个rsync同步服务

【核心要点】

备份数据库的命令

同步到远程服务器的命令

本地一周,可以用 date +%w做后缀,远程一个月可以用date +%d作为后缀

【脚本】

#!/bin/bash

d1=`date +%w`
d2=`date +%d`
local_bakdir=/bak/mysql
romote_bakdir=192.168.1.100::backup

exec 1> /tmp/mysqlbak.log 2>/tmp/mysqlbak.err
echo "mysql backup begin at `date`"
mysqldump -uroot -pxxxx data123 > $local_bakdir/data123.sql.$d1
rsync -az $local_bakdir/discuz.sql.$d1 $remote_bakdir/discuz.sql.$d2
echo "mysql backup end at `date`"

 

扫码关注我们
微信号:SRE实战
拒绝背锅 运筹帷幄