2024-03-15 15:38:34 +08:00

211 lines
7.8 KiB
Bash
Executable File
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

#!/bin/bash
# 备份目录脚本
# 参数配置
## 版本号
version="0.3.0"
## 当前的日期、日期时间
date=`date +%Y%m%d`
datetime=`date +%Y%m%d`_`date +%H%M%S`
## 需要备份的目录名称
dirName=$1
## 需要备份的文件夹(绝对路径)
backupPath=$2
## 备份成果文件名称
backupFileName=$dirName"_backup_"$datetime".tar.gz"
## 是否生成备份成果文件哈希值【0不生成1生成】
generateBackupFileSHA=1
## 是否加密【0不加密1加密】
needEncrypt=1
## 加密使用的 OpenSSL 来源【0宿主机1Docker】
opensslType=0
## OpenSSL Docker 镜像
opensslImage=hub.hty1024.com/hty1024/openssl:3.1.4
## 加密秘钥文件(秘钥为文件的第一行内容)
encryptPasswordFile=$3
## 备份模式【0备份到本地目录1备份到Amazon S32备份到华为云OBS3备份到腾讯云COS】
model=0
## 备份文件保存路径(仅当 model 为 0 时生效)
targetsPath=/bak/$dirName
## S3 桶名称(仅当 model 为 1 时生效)
s3BucketName=demo
## S3 目录(仅当 model 为 1 时生效)
s3FolderName=$dirName
## obsutilOBS工具 路径(绝对路径)
obsutil=/opt/obsutil/obsutil
## OBS 桶名称(仅当 model 为 2 时生效)
obsBucketName=demo
## OBS 目录(仅当 model 为 2 时生效)
obsFolderName=$dirName
## coscliCOS工具路径绝对路径
coscli=/opt/coscli/coscli
## COS 桶名称(仅当 model 为 3 时生效)
cosBucketName=demo
## COS 目录(仅当 model 为 3 时生效)
cosFolderName=$dirName
## COS 对象类型(仅当 model 为 3 时生效【STANDARD标准存储MAZ_STANDARD标准存储多AZSTANDARD_IA低频存储MAZ_STANDARD_IA低频存储多AZMAZ_INTELLIGENT_TIERING智能分层存储ARCHIVE归档存储DEEP_ARCHIVE深度归档存储】
cosStorageClass=STANDARD
## 临时路径(临时的工作目录)
tmpPath=/tmp/backup/$dirName/$date
# 相关方法
## 帮助信息
help () {
echo 'Usage: bf 需要备份的目录名称 需要备份的目录 加密秘钥文件'
echo '参数说明:'
echo ' $1 需要备份的目录名称,将使用此名称新增备份文件夹及文件'
echo ' $2 需要备份的目录(绝对路径)'
echo ' $3 加密秘钥文件(可选,仅加密备份文件时需指定)'
echo '示例:'
echo ' 备份 home 目录: bf home /home'
echo ' 备份 home 目录,并使用 /root/home.key 文件作为秘钥加密备份文件: bf home /home /root/home.key'
echo '其他说明:'
echo ' 1、使用前请按实际情况修改备份文件保存方式'
echo ' 2、若使用远程存储如 Amazon S3 等)则需要安装相关 cli 工具并完成配置,安装及配置方式请参考官方文档;'
echo ' 3、若需加密备份文件则需安装 openssl ,安装方式请参考官方文档。'
}
## 版本号
version () {
echo 'bf '$version
}
## 创建临时目录
createTmpPath () {
echo '------------------------------ 开始创建工作目录... ------------------------------'
mkdir -pv $tmpPath
echo '------------------------------ 工作目录创建完成! ------------------------------'
}
## 压缩备份目录
condense () {
echo '------------------------------ 开始压缩备份目录... ------------------------------'
cd $tmpPath
tar czPf $backupFileName $backupPath
echo '------------------------------ 备份目录压缩成功! ------------------------------'
}
## 生成备份文件哈希值
generateSHA () {
echo '------------------------------ 开始生成备份文件哈希... ------------------------------'
cd $tmpPath
openssl dgst -sha512 -out $backupFileName'_SHA512' $backupFileName
mkdir -pv $targetsPath
mv $backupFileName'_SHA512' $targetsPath
echo '------------------------------ 备份文件哈希生成成功( 哈希文件见:' $targetsPath ' ------------------------------'
}
## 使用宿主机内置的 OpenSSL 加密
encryptByHost () {
echo '****************************** 使用主机内置 OpenSSL 进行加密 ******************************'
cd $tmpPath
mv $backupFileName bak_$backupFileName
openssl enc -e -aes256 -a -kfile $encryptPasswordFile -in bak_$backupFileName -out $backupFileName
rm -rf bak_$backupFileName
}
## 使用 Docker 运行 OpenSSL 容器加密
encryptByDocker () {
echo '****************************** 运行 OpenSSL Docker 容器进行加密 ******************************'
cd $tmpPath
mkdir data
cp -rpf $encryptPasswordFile ./data/key
mv $backupFileName ./data/bak_$backupFileName
chown 1024.1024 -R ./data
docker run -dit --name openssl -v ./data:/data $opensslImage
docker exec -it openssl openssl enc -e -aes256 -a -kfile /data/key -in /data/bak_$backupFileName -out /data/$backupFileName
cp -rpf data/$backupFileName ./
docker rm -f openssl
}
## 加密备份文件
encrypt () {
echo '------------------------------ 开始加密备份文件... ------------------------------'
case $opensslType in
1)
encryptByDocker
;;
*)
encryptByHost
;;
esac
echo '------------------------------ 备份文件加密成功! ------------------------------'
}
## 将备份文件保存到本地
saveToLocal () {
echo '****************************** 使用本地模式,将保存备份文件到本地目录( '$targetsPath' ******************************'
mkdir -pv $targetsPath
mv $tmpPath/$backupFileName $targetsPath/$backupFileName
}
## 将备份文件保存到Amazon S3
saveToS3 () {
echo '****************************** 使用 S3 模式,将保存备份文件到 Amazon S3 桶( '$obsBucketName' ******************************'
aws s3 cp $tmpPath/$backupFileName s3://$s3BucketName/$s3FolderName/$backupFileName
rm -rf $tmpPath/$backupFileName
}
## 将备份文件保存到华为云 OBS
saveToOBS () {
echo '****************************** 使用 OBS 模式,将保存备份文件到 华为云 OBS 桶( '$obsBucketName' ******************************'
$obsutil mkdir obs://$obsBucketName/$obsFolderName
$obsutil cp -f $tmpPath/$backupFileName obs://$obsBucketName/$obsFolderName/$backupFileName
rm -rf $tmpPath/$backupFileName
}
## 将备份文件保存到腾讯云 COS
saveToCOS () {
echo '****************************** 使用 COS 模式,将保存备份文件到 腾讯云 COS 桶( '$cosBucketName' ******************************'
$coscli cp $tmpPath/$backupFileName cos://$cosBucketName/$cosFolderName/$backupFileName --storage-class $cosStorageClass
rm -rf $tmpPath/$backupFileName
}
## 保存备份文件
save () {
echo '------------------------------ 开始保存备份文件... ------------------------------'
case $model in
0)
saveToLocal
;;
1)
saveToS3
;;
2)
saveToOBS
;;
3)
saveToCOS
;;
*)
saveToLocal
;;
esac
echo '------------------------------ 备份文件保存成功! ------------------------------'
}
## 备份
bf () {
echo '===================================================================================================='
echo `date +%Y-%m-%d` `date +%H:%M:%S`
echo '============================== 开始备份 '$dirName' ...... =============================='
### 创建工作目录
createTmpPath
### 打包备份目录
condense
### 加密备份文件
if [ $needEncrypt == 1 ];then
encrypt
fi
### 生成备份文件哈希
if [ $generateBackupFileSHA == 1 ];then
generateSHA
fi
### 保存备份文件
save
echo '============================== '$dirName' 备份成功!!! =============================='
echo `date +%Y-%m-%d` `date +%H:%M:%S`
echo '===================================================================================================='
}
# 执行方法
case $1 in
help)
help
;;
version)
version
;;
*)
bf
;;
esac