#!/bin/sh
number=3
##数据库相关
host=xxxxx
user=xxxxx
password=xxxxx
db=xxxfxxxx
path=/data/db/dbBackup/
time=`date +%Y%m%d`
###time=`date +%Y%m%d%H%M%S`
file=gw_wf_bandian_$time.sql
filegz=gw_wf_bandian_$time.sql.gz
###挂载相关
remotePath=//192.168.1.10/shareBackup ###远程共享地址
mountPath=/data/mount/ ###挂载位置
mountuser=user
mountpass=pass
mysqldump -h$host -p 3306 -u$user -p$password $db [数据表名] > $path$file
###备份成压缩文件
mysqldump -h$host -p 3306 -u$user -p$password $db [数据表名] | gzip > $path$filegz
###找出要删除的备份 本地
###awk '{print $9 }' 获取到第9列
###ls -l -crt
##-t:用文件和目录的更改时间排序
##-r:以文件名反序排列并输出目录内容列表
##-c: 按照文件状态时间排序输出目录内容
delfile1=`ls -l -crt $path*.sql | awk '{print $9 }' | head -1`
###判断现在的备份数量是否大于$number 本地
count1=`ls -l -crt $path*.sql | awk '{print $9 }' | wc -l`
if [ $count1 -gt $number ]
then
rm $delfile1
echo '删除 ' $delfile1
fi
### 挂载共享文件夹
sleep 1s
if [ ! -d $mountPath ]; then mkdir -p $mountPath; fi
idmount=`df -h | grep $remotePath`
if [ ${#idmount} -le 0 ];then
mount -t cifs -o username=$mountuser,password=$mountpass,iocharset=utf8,dir_mode=0777,file_mode=0777 $remotePath $mountPath
fi
###找出要删除的备份 共享
delfile2=`ls -l -crt $mountPath*.sql | awk '{print $9 }' | head -1`
###判断现在的备份数量是否大于$number 共享
count2=`ls -l -crt $mountPath*.sql | awk '{print $9 }' | wc -l`
if [ $count2 -gt $number ]; then
rm $delfile2
echo '删除 ' $delfile2
fi
cp $path* $mountPath