I have a working gitolite server. However, I want to move it to an identical configuration, but on a bigger machine. Even though I have gitolite working, I am not sure about t
The instructions have changed for Gitolite V3
(Copied from http://gitolite.com/gitolite/rare.html):
Install gitolite on the new server, using the same key for the admin as for the old server.
Copy the .gitolite.rc
file from the old server, overwriting this one.
Disable the old server so people won't push to it. There are several ways to do this, but the simplest is to insert exit 1;
at the top of ~/.gitolite.rc
on the old server:
Copy all the repos over from the old server, including gitolite-admin
. Make sure the files end up with the right ownership and permissions; if not, chown/chmod them.
Run gitolite setup
.
On a clone of the old gitolite-admin, add a new remote (or change an existing one) to point to the new server. Then git push -f
to this remote.
What you will need is also to move your ssh config:
~/.ssh/authorized_keys
That is the file used by SSH and configured by Gitolite in order to:
See "How Gitolite uses ssh"
The OP confirms that was the issue and points out to the Gitolite documentation:
"moving the whole thing from one server to another":
(note: this is for 'g2'; ie Gitolite V2, but the idea is the same for Gitolite V3 or 'g3')
The idea behind this process is to create a new Gitolite instance, and then push your existing Gitolite repo, which will redeclare automatically all your current existing keys in your new server ~/.ssh authorized_keys
for you.
install gitolite. Don't worry about the pubkey used in the gl-setup step -- for example this will do fine:
ssh-keygen -q -N '' -f dummy gl-setup -q dummy.pub
edit the rc file to have similar settings to the old one.
Do not copy the entire file outright -- some of the variables (notably GL_PACKAGE_CONF
and GL_PACKAGE_HOOKS
) are installation dependent and should not be touched!
Do a diff
or a vimdiff
and copy across only what you know you changed on the old server.
disable the old server so your users will not push any changes to it.
There are several ways to do this, but the simplest is to insert this line at the top of ~/.gitolite.rc
on the old server:
exit 1;
copy the contents of $REPO_BASE
in the old server to $REPO_BASE
on the new server.
By default, as you know, these are both $HOME/repositories
.
chown -R
the files to the correct user if you copied using root.
fix up the hooks
gl-setup
trigger a push to the admin repo
git clone repositories/gitolite-admin.git /tmp/gitolite-admin cd /tmp/gitolite-admin git commit --allow-empty -m 'trigger compile on new server' gl-admin-push -f