centos下mysql数据备份到Windows系统共享

#!/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

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值