Moving gitolite server
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:
- list all the authorized public key
- associated it with a forced-command script
- pass the right user name to the gitolite script
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
andGL_PACKAGE_HOOKS
) are installation dependent and should not be touched!
Do adiff
or avimdiff
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
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.