@@ -84,7 +84,7 @@ defining the basis. More than one reference may be packaged, and more
84
84
than one basis can be specified. The objects packaged are those not
85
85
contained in the union of the given bases. Each basis can be
86
86
specified explicitly (e.g., ^master~10), or implicitly (e.g.,
87
- master~10..master, master --since=10.days.ago).
87
+ master~10..master, --since=10.days.ago master ).
88
88
89
89
It is very important that the basis used be held by the destination.
90
90
It is okay to err on the side of conservatism, causing the bundle file
@@ -94,75 +94,111 @@ when unpacking at the destination.
94
94
EXAMPLE
95
95
-------
96
96
97
- Assume two repositories exist as R1 on machine A, and R2 on machine B.
97
+ Assume you want to transfer the history from a repository R1 on machine A
98
+ to another repository R2 on machine B.
98
99
For whatever reason, direct connection between A and B is not allowed,
99
100
but we can move data from A to B via some mechanism (CD, email, etc).
100
101
We want to update R2 with developments made on branch master in R1.
101
102
102
- To create the bundle you have to specify the basis. You have some options:
103
+ To bootstrap the process, you can first create a bundle that doesn't have
104
+ any basis. You can use a tag to remember up to what commit you sent out
105
+ in order to make it easy to later update the other repository with
106
+ incremental bundle,
103
107
104
- - Without basis.
105
- +
106
- This is useful when sending the whole history.
108
+ ----------------
109
+ machineA$ cd R1
110
+ machineA$ git bundle create file.bdl master
111
+ machineA$ git tag -f lastR2bundle master
112
+ ----------------
107
113
108
- ------------
109
- $ git bundle create mybundle master
110
- ------------
114
+ Then you sneakernet file.bdl to the target machine B. Because you don't
115
+ have to have any object to extract objects from such a bundle, not only
116
+ you can fetch/pull from a bundle, you can clone from it as if it was a
117
+ remote repository.
111
118
112
- - Using temporally tags.
113
- +
114
- We set a tag in R1 (lastR2bundle) after the previous such transport,
115
- and move it afterwards to help build the bundle.
119
+ ----------------
120
+ machineB$ git clone /home/me/tmp/file.bdl R2
121
+ ----------------
116
122
117
- ------------
118
- $ git bundle create mybundle master ^lastR2bundle
119
- $ git tag -f lastR2bundle master
120
- ------------
123
+ This will define a remote called "origin" in the resulting repository that
124
+ lets you fetch and pull from the bundle. $GIT_DIR/config file in R2 may
125
+ have an entry like this:
121
126
122
- - Using a tag present in both repositories
127
+ ------------------------
128
+ [remote "origin"]
129
+ url = /home/me/tmp/file.bdl
130
+ fetch = refs/heads/*:refs/remotes/origin/*
131
+ ------------------------
132
+
133
+ You can fetch/pull to update the resulting mine.git repository after
134
+ replacing the bundle you store at /home/me/tmp/file.bdl with incremental
135
+ updates from here on.
136
+
137
+ After working more in the original repository, you can create an
138
+ incremental bundle to update the other:
139
+
140
+ ----------------
141
+ machineA$ cd R1
142
+ machineA$ git bundle create file.bdl lastR2bundle..master
143
+ machineA$ git tag -f lastR2bundle master
144
+ ----------------
145
+
146
+ and sneakernet it to the other machine to replace /home/me/tmp/file.bdl,
147
+ and pull from it.
148
+
149
+ ----------------
150
+ machineB$ cd R2
151
+ machineB$ git pull
152
+ ----------------
123
153
124
- ------------
125
- $ git bundle create mybundle master ^v1.0.0
126
- ------------
154
+ If you know up to what commit the intended recipient repository should
155
+ have the necessary objects for, you can use that knowledge to specify the
156
+ basis, giving a cut-off point to limit the revisions and objects that go
157
+ in the resulting bundle. The previous example used lastR2bundle tag
158
+ for this purpose, but you can use other options you would give to
159
+ the linkgit:git-log[1] command. Here are more examples:
127
160
128
- - A basis based on time .
161
+ You can use a tag that is present in both .
129
162
130
- ------------
131
- $ git bundle create mybundle master --since=10.days.ago
132
- ------------
163
+ ----------------
164
+ $ git bundle create mybundle v1.0.0..master
165
+ ----------------
133
166
134
- - With a limit on the number of commits
167
+ You can use a basis based on time.
135
168
136
- ------------
137
- $ git bundle create mybundle master -n 10
138
- ------------
169
+ ----------------
170
+ $ git bundle create mybundle --since=10.days master
171
+ ----------------
139
172
140
- Then you move mybundle from A to B, and in R2 on B:
173
+ Or you can use the number of commits.
141
174
142
- ------------
175
+ ----------------
176
+ $ git bundle create mybundle -10 master
177
+ ----------------
178
+
179
+ You can run `git-bundle verify` to see if you can extract from a bundle
180
+ that was created with a basis.
181
+
182
+ ----------------
143
183
$ git bundle verify mybundle
144
- $ git fetch mybundle master:localRef
145
- ------------
184
+ ----------------
146
185
147
- With something like this in the config in R2:
186
+ This will list what commits you must have in order to extract from the
187
+ bundle and will error out if you don't have them.
148
188
149
- ------------------------
150
- [remote "bundle"]
151
- url = /home/me/tmp/file.bdl
152
- fetch = refs/heads/*:refs/remotes/origin/*
153
- ------------------------
189
+ A bundle from a recipient repository's point of view is just like a
190
+ regular repository it fetches/pulls from. You can for example map
191
+ refs, like this example, when fetching:
154
192
155
- You can first sneakernet the bundle file to ~/tmp/file.bdl and
156
- then these commands on machine B:
193
+ ----------------
194
+ $ git fetch mybundle master:localRef
195
+ ----------------
157
196
158
- ------------
159
- $ git ls-remote bundle
160
- $ git fetch bundle
161
- $ git pull bundle
162
- ------------
197
+ Or see what refs it offers.
163
198
164
- would treat it as if it is talking with a remote side over the
165
- network.
199
+ ----------------
200
+ $ git ls-remote mybundle
201
+ ----------------
166
202
167
203
Author
168
204
------
0 commit comments