所有分支都使用git bundle进行增量备份

Juk*_*ela 21 git backup

使用git存储库进行增量备份的最简单方法是什么git bundle

如果我只想备份一个分支,我可以沿着这些方向做一些事情:

git bundle create foo last-backup..master
git tag -f last-backup master
Run Code Online (Sandbox Code Playgroud)

但是如果我想备份所有内容(包括所有分支)呢?


要回答评论中的问题:

严格地说,只要解决方案满足以下属性,我就不需要使用通常的Git包:

  • 每个增量备份都是一个文件.我可以将它存储在某个地方,后续的增量备份不需要修改此文件.

  • 文件大小约等于自上次备份以来Git提交的总大小.二进制文件的更改也可以有效地存储.

  • 从那时起,完整备份+所有增量备份包含自动重建存储库所需的所有内容,包括所有分支.

(作为一个简单的例子,简单地在git存储库中构建一个包含最近更改过的文件的tar存档,如果发生自动垃圾收集,则无法满足第二个要求.)

理想情况下,我还希望有一个防止白痴的系统:

  • 我几乎可以对我的Git存储库进行任何完整备份,以及所有最近的增量备份,我可以简单地"拉"备份中的所有内容,并且存储库将是最新的.特别是,完全备份和增量备份之间是否存在部分重叠并不重要.

如果我只需要处理一个分支,Git捆绑包就能很好地满足这一切.

opq*_*nut 13

(我们与Jukka讨论了这个问题,这是结果.)

预赛:

  1. 让最后一个备份可用 backup.bundle
  2. 有一个backup指向的遥控器backup.bundle

进行备份:

  1. git fetch backup - 只是为了确保我们是最新的
  2. git bundle create newbackup.bundle ^backup/A ^backup/B A B C
    • 这意味着我们创建了一个包,它排除了包中已有的所有内容
    • 从中生成所需的^backup/A样式参数很容易refs/remotes/backup/
    • 同样,A-style参数来自refs/heads
  3. 复制newbackup.bundle到您保留备份的任何位置
  4. 替换为backup.bundle,newbackup.bundle因此您知道从哪里开始下一次增量备份

恢复:

  1. 拥有一个空的存储库或代表存储库的旧版本
  2. 对于每个备份文件,按顺序:
    1. git remote rm recovery
    2. git remote add recovery <name-of-bundle>
    3. git fetch recovery - 您需要命名遥控器以使其正常工作
  3. 现在你应该有每个分支 refs/remotes/backup


oni*_*ake 6

尝试使用--since和--all.

创建第一个备份:

git bundle create mybundle-all --all
Run Code Online (Sandbox Code Playgroud)

进行增量备份:

git bundle create mybundle-inc --since=10.days --all
Run Code Online (Sandbox Code Playgroud)

增量应包含过去10天内发生的所有分支上的所有提交.确保--since参数回溯得足够远,否则您可能会错过提交.如果在该时间范围内没有发生任何提交,Git也将拒绝创建捆绑包,因此请做好计划.