首页 > 其他分享 >Borg 增量备份方案

Borg 增量备份方案

时间:2022-09-28 14:34:43浏览次数:75  
标签:info -- 备份 global exit 增量 Borg Backup

一、为什么选择 BorgBackup

Borg Backup 是目前最受欢迎,用户量最大的一个备份支持程序,支持去重和压缩,同时也支持认证加密。其主要目的是提供一个高效而且安全的方法用于数据备份。数据的去重技术用于每日增量备份。它支持Linux、MacOS和BSD,并遵循BSD许可协议

BorgBackup 的主要优势:

  • 高效:BorgBackup 会将文件按数据块去重,只有改动的数据块才会被备份。一个 25 GiB 的虚拟机磁盘文件,只改动了 1 GiB,那就只会新增备份这 1 GiB 的数据;
  • 高速:核心算法使用 C 编译,使用缓存快速跳过未改动过的文件以加快备份速度;
  • 加密:数据默认是 AES-256 加密并且 HMAC-SHA256 校验的;
  • 压缩:支持多种压缩算法,可自动检测数据是否属于可被压缩的类型;
  • 异地备份:原生支持 SSH 备份到异地服务器,也可使用 NFS 等网络存储;
  • 可挂载:可以直接用 FUSE 挂载一个备份存档读取里面的数据;
  • 跨平台:支持 Linux, macOS, BSD, Windows (Cygwin / WSL) 等多种平台;
  • 开源:安全可审计,易于修改。

官网

https://www.borgbackup.org/

#!/bin/sh

# Setting this, so the repo does not need to be given on the commandline:
export BORG_REPO=ssh://[email protected]:2022/~/backup/main

# See the section "Passphrase notes" for more infos.
export BORG_PASSPHRASE='XYZl0ngandsecurepa_55_phrasea&&123'

# some helpers and error handling:
info() { printf "\n%s %s\n\n" "$( date )" "$*" >&2; }
trap 'echo $( date ) Backup interrupted >&2; exit 2' INT TERM

info "Starting backup"

# Backup the most important directories into an archive named after
# the machine this script is currently running on:

borg create                         \
    --verbose                       \
    --filter AME                    \
    --list                          \
    --stats                         \
    --show-rc                       \
    --compression lz4               \
    --exclude-caches                \
    --exclude 'home/*/.cache/*'     \
    --exclude 'var/tmp/*'           \
                                    \
    ::'{hostname}-{now}'            \
    /etc                            \
    /home                           \
    /root                           \
    /var                            \

backup_exit=$?

info "Pruning repository"

# Use the `prune` subcommand to maintain 7 daily, 4 weekly and 6 monthly
# archives of THIS machine. The '{hostname}-' prefix is very important to
# limit prune's operation to this machine's archives and not apply to
# other machines' archives also:

borg prune                          \
    --list                          \
    --prefix '{hostname}-'          \
    --show-rc                       \
    --keep-daily    7               \
    --keep-weekly   4               \
    --keep-monthly  6               \

prune_exit=$?

# actually free repo disk space by compacting segments

info "Compacting repository"

borg compact

compact_exit=$?

# use highest exit code as global exit code
global_exit=$(( backup_exit > prune_exit ? backup_exit : prune_exit ))
global_exit=$(( compact_exit > global_exit ? compact_exit : global_exit ))

if [ ${global_exit} -eq 0 ]; then
    info "Backup, Prune, and Compact finished successfully"
elif [ ${global_exit} -eq 1 ]; then
    info "Backup, Prune, and/or Compact finished with warnings"
else
    info "Backup, Prune, and/or Compact finished with errors"
fi

exit ${global_exit}

  

标签:info,--,备份,global,exit,增量,Borg,Backup
From: https://www.cnblogs.com/dgp-zjz/p/16737944.html

相关文章

  • SQL Server触发器备份后还原
    测试环境SQLServer2012selecta.definition,b.name,b.is_disabledfromsys.sql_modulesainnerjoinsys.triggersbona.object_id=b.object_id--所有的触发......
  • linux 自动备份Oracle
    1.root用户登录oracle服务器#新建Oracle数据库备份存放目录mkdir–p/home/oracle/backup#设置目录权限为oinstall用户组的oracle用户chown-roracle:oinstall/......
  • netmiko交换机备份
    importnetmikoimporttimefromnetmikoimportConnectHandlerimportosimportthreadingfromqueueimportQueue#定义用户名和密码变量user=交换机用户pawd=......
  • Linux下定时自动备份Docker中所有SqlServer数据库
    准备工作一台Linux(Centos7为例)服务器。安装Docker服务。安装并启动SqlServer容器服务。编写Shell文件给出一个备份的范例#!/bin/bash#设置mssql备份目录folder......
  • ubuntu 将现有的系统备份iso,做成系统盘
    Systemback提供相关的操作1.查看系统的信息test@test-OptiPlex-3050:~$uname-aLinuxtest-OptiPlex-30504.15.0-142-generic#146~16.04.1-UbuntuSMPTueApr1309......
  • 主从不同步,忽略一张表进行备份恢复
    1.从库停止备份stopslave;2.主库备份mysqldump-uroot-p'1qaz@WSX'-h$ip--single-transaction--triggers--set-gtid-purged=OFF--routines--events--master-da......
  • day02 --> (DQL、约束、多表之间的关系、范式、数据库的备份和还原)
    一、DQL:查询语句1.排序查询语法:orderby子句orderby排序字段1排序方式1,排序字段2排序方式2...排序方式:ASC:升序,默认DESC:降序注意:如果有多个排序条件,则当前......
  • rsync 同步日志到备份机器
    检查是否安装软件[root@test~]#rpm-qa|greprsyncrsync-3.1.2-10.el7.x86_64 服务器配置cat/etc/rsyncd.confuid=rootgid=rootusechroot=noma......
  • Linux备份文件加“时间”命令
    好记性不如烂笔头,好用。date命令用于显示及设置系统的时间或日期,如何设置时间此处不再多说。date命令非常强大,可以将数据备份命令与date命令结合在一起使用,可以便捷的分......
  • Oracle表数量对数据泵备份恢复速度的影响情况
    Oracle表数量对数据泵备份恢复速度的影响情况背景随着公司产品交付后的时间越来越久.数据库的备份恢复速度会越来越慢.最开始一直认为是因为数据量导致的.但是最近......