备份脚本
#!/bin/bash
#author cheng
#备份服务器自动打包归档每天的备份文件
Path=/backhistory
Host=$(hostname)
Date=$(date +%F)
Dest=${Host}_${Date}
#创建目录
mkdir -p ${Path}/${Dest}
#打包文件到目录
cd / && \
#结合autoback.sh脚本,它往那个地方备,我们就打包那个地方
tar zcvPf ${Path}/${Dest}/back.tar.gz /backup && \
#只保留最近7天的数据
find ${Path}/ -type d -mtime +7 | xargs rm -rf {}
打包、传输到备份服务器脚本
#!/bin/bash
#author cheng
#客户端自动备份重要文件到备份服务器
# 将备份列表文件的路径保存到变量中
backupf='./bckup.txt'
# 输入一个提示信息
echo "Shell Script Backup Your Files / Directories Using rsync"
# 检查是否输入了目标服务器,如果为空就再次提示用户输入
while [ x$desthost = "x" ]; do
# 提示用户输入目标服务器地址并保存到变量
read -p "Destination backup Server : " desthost
# 结束循环
done
# 检查是否输入了目标文件夹,如果为空就再次提示用户输入
while [ x$destpath = "x" ]; do
# 提示用户输入目标文件夹并保存到变量
read -p "Destination Folder : " destpath
# 结束循环
done
# 检查是否输入了目标服务器密码,如果为空就再次提示用户输入
while [ x$password = "x" ]; do
# 提示用户输入密码并保存到变量
# 使用 -s 选项不回显输入的密码
read -sp "Password : " password
# 结束循环
done
# 逐行读取备份列表文件
for line in `cat $backupf`
# 对每一行都进行处理
do
# 显示要被复制的文件/文件夹名称
echo "Copying $line ... "
# 使用 expect 来在脚本中输入密码
/usr/bin/expect << EOD
# 推荐设置超时为 -1
set timeout -1
# 通过 rsync 复制文件/文件夹到目标位置,使用 expect 的组成部分 spawn 命令
spawn rsync -ar ${line} ${desthost}:${destpath}
# 上一行命令会等待 "password" 提示
expect "*?assword:*"
# 在脚本中提供密码
send "${password}\r"
# 等待文件结束符(远程服务器处理完了所有事情)
expect eof
# 结束 expect 脚本
EOD
# 显示结束
echo "DONE"
# 完成
done
说明
需要安装两个工具来实现快速快速传输(rsync)和人机交互(expect)
centos安装rsync
yum -y install rsync.x86_64
启动服务(只使用ssh协议的话,可以不开这个服务)
service rsyncd start
centos安装 expect
yum -y install expect