git bundle create
Uno dei metodi consiste nell'utilizzare l'archiviazione esterna per scambiare dati tra repository è il bundle git . In questo modo hai solo file singoli per ogni trasferimento, non repository Git intermedi.
Ogni "git push" si trasforma in creazione di un file, "git fetch" recupera le cose da quel file.
Sessione demo
Creare il primo repository e fare il primo "push"
gitbundletest$ mkdir repo1
gitbundletest$ cd repo1
repo1$ git init
Initialized empty Git repository in /tmp/gitbundletest/repo1/.git/
repo1$ echo 1 > 1 && git add 1 && git commit -m 1
[master (root-commit) c8b9ff9] 1
1 file changed, 1 insertion(+)
create mode 100644 1
repo1$ git bundle create /tmp/1.bundle master HEAD
Enumerating objects: 3, done.
Counting objects: 100% (3/3), done.
Writing objects: 100% (3/3), 384 bytes | 384.00 KiB/s, done.
Total 3 (delta 0), reused 0 (delta 0)
"clonazione" nel secondo repository (ovvero il secondo computer):
gitbundletest$ git clone /tmp/1.bundle repo2
Cloning into 'repo2'...
Receiving objects: 100% (3/3), done.
gitbundletest$ cd repo2/
repo2$ cat 1
1
Apportare alcune modifiche e "trasferirle" in un altro file bundle:
repo2$ echo 2 > 1 && git add 1 && git commit -m 2
[master 250d387] 2
1 file changed, 1 insertion(+), 1 deletion(-)
repo2$ git bundle create /tmp/2.bundle origin/master..master origin/HEAD..HEAD
Enumerating objects: 5, done.
Counting objects: 100% (5/5), done.
Writing objects: 100% (3/3), 415 bytes | 415.00 KiB/s, done.
Total 3 (delta 0), reused 0 (delta 0)
"pull" cambia nel primo repository:
repo2$ cd ../repo1
repo1$ git pull /tmp/2.bundle
Receiving objects: 100% (3/3), done.
From /tmp/2.bundle
* branch HEAD -> FETCH_HEAD
Updating c8b9ff9..250d387
Fast-forward
1 | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
repo1$ cat 1
2
A differenza del primo bundle, il secondo contiene solo una cronologia parziale di Git e non è direttamente clonabile:
repo1$ cd ..
gitbundletest$ git clone /tmp/2.bundle repo3
Cloning into 'repo3'...
error: Repository lacks these prerequisite commits:
error: c8b9ff94942039469fa1937f6d38d85e0e39893a
fatal: bad object 250d38747656401e15eca289a27024c61e63ed68
fatal: remote did not send all necessary objects
C'è uno svantaggio nell'uso dei bundle che è necessario specificare manualmente quale intervallo di commit dovrebbe contenere ciascun bundle. Diversamente git push
, git bundle
non tiene traccia di ciò che era nel pacchetto precedente, è necessario regolare manualmente refs/remotes/origin/master
o i pacchetti sarebbero più grandi di quanto potrebbero essere.