Using svnsync
Original Article
svnsync is a one way replication system for Subversion. It allows you to create a read-only replica of a repository over any RA layer (including http, https, svn, svn+ssh).
First, lets setup the initial sync. We have two repositories, I will skip the details of svnadmin create. For the remote access to the replica repository, I used svnserve, and I added a user with full write access. The destination repository should be completely empty before starting.
So, to make this easier, I am going to put the repository URIs into enviroment variables:
On the server hosting TOREPO, I ran this:
We are now ready to begin copying data:
Except, I suck. And the first thing I did was hit control+c. I figured this is a cool replication system, so I just ran the
I started debugging, and found that svnsync kept its lock state in a special property in revision zero again.
So, To fix this, we can safely just delete this lock:
Now running
After the sync finishes, we will want to keep the replica up to date.
I personally set a ‘live’ sync, but it is also possible to use a crontab or other scheduling method to invoke sync whenever you want.
To setup a live sync, on the FROMREPO server, I appended this to my hooks/post-commit file:
Unfortunately, the post-commit hook won’t catch everything, so we also need to added this to the
And there you go, thats the path I took to mirror one of my repositories onto another machine.
svnsync is a one way replication system for Subversion. It allows you to create a read-only replica of a repository over any RA layer (including http, https, svn, svn+ssh).
First, lets setup the initial sync. We have two repositories, I will skip the details of svnadmin create. For the remote access to the replica repository, I used svnserve, and I added a user with full write access. The destination repository should be completely empty before starting.
So, to make this easier, I am going to put the repository URIs into enviroment variables:
$ export FROMREPO=svn://svn.example.com/ $ export TOREPO=svn://dest.example.com/Because the svnsync is allowed to rewrite anything on the TOREPO, we need to make sure the commit hooks are configured to allow our ‘svnsync’ user to do anything it wants.
On the server hosting TOREPO, I ran this:
$ echo "#!/bin/sh" > hooks/pre-revprop-change $ chmod 755 hooks/pre-revprop-changeNow we are ready to setup the sync:
$ svnsync init ${TOREPO} ${FROMREPO}
This will prompt you for the username, password, and also sets  several revision properties on the $TOREPO, for revision zero.  It  doesn’t actually copy any of the data yet. To list the properties that  it created, run:$ svn proplist --revprop -r 0 ${TOREPO}
  svn:sync-from-uuid
  svn:sync-last-merged-rev
  svn:date
  svn:sync-from-url
$ svn propget svn:sync-from-url --revprop -r 0 ${TOREPO}
  svn://svn.example.com/
So all the knowledge about what we are syncing from is stored at the  destination repository. No state about this sync is stored in the source  repository.We are now ready to begin copying data:
$ svnsync --non-interactive sync ${TOREPO}And if everything is setup correctly, you will start replicating data.Except, I suck. And the first thing I did was hit control+c. I figured this is a cool replication system, so I just ran the
sync command from above again, and got this:$ svnsync --non-interactive sync ${TOREPO}
Failed to get lock on destination repos, currently held by 'svn.example.com:0e4e0d98-631d-0410-9a00-9320a90920b3'
Failed to get lock on destination repos, currently held by 'svn.example.com:0e4e0d98-631d-0410-9a00-9320a90920b3'
Failed to get lock on destination repos, currently held by 'svn.example.com:0e4e0d98-631d-0410-9a00-9320a90920b3'
Failed to get lock on destination repos, currently held by 'svn.example.com:0e4e0d98-631d-0410-9a00-9320a90920b3'
Failed to get lock on destination repos, currently held by 'svn.example.com:0e4e0d98-631d-0410-9a00-9320a90920b3'
Failed to get lock on destination repos, currently held by 'svn.example.com:0e4e0d98-631d-0410-9a00-9320a90920b3'
Failed to get lock on destination repos, currently held by 'svn.example.com:0e4e0d98-631d-0410-9a00-9320a90920b3'
Failed to get lock on destination repos, currently held by 'svn.example.com:0e4e0d98-631d-0410-9a00-9320a90920b3'
Failed to get lock on destination repos, currently held by 'svn.example.com:0e4e0d98-631d-0410-9a00-9320a90920b3'
Failed to get lock on destination repos, currently held by 'svn.example.com:0e4e0d98-631d-0410-9a00-9320a90920b3'
svnsync: Couldn't get lock on destination repos after 10 attempts
Oh snap.  I guess its not so easy to  restart after an aborted sync. I started debugging, and found that svnsync kept its lock state in a special property in revision zero again.
So, To fix this, we can safely just delete this lock:
$ svn propdel svn:sync-lock --revprop -r 0  ${TOREPO}
Now running
sync again works! Hurrah!After the sync finishes, we will want to keep the replica up to date.
I personally set a ‘live’ sync, but it is also possible to use a crontab or other scheduling method to invoke sync whenever you want.
To setup a live sync, on the FROMREPO server, I appended this to my hooks/post-commit file:
svnsync --non-interactive sync svn://dest.example.com/ &You will want to make sure that the user-running subversion (and the hook script) has a cached copy of the authentication info for the destination repository.
Unfortunately, the post-commit hook won’t catch everything, so we also need to added this to the
post-revprop-change hook:svnsync --non-interactive copy-revprops  svn://dest.example.com/ ${REV} &
This will help propagate things like editing svn:log messages.And there you go, thats the path I took to mirror one of my repositories onto another machine.
 
 
No comments:
Post a Comment