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 the strings under it. Mainly its relationship with ssh.
I would like to just install the packages gitolite, git-core. And move the repository directories for the git user. None of the keys need to change. Is this correct ? what are the configuration ties gitolite has to the current server. I am working with Ubuntu
I was specially confused by gl-setup, which did the job, but leaves me in the dark about the process.
Thanks
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
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
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.