Backing up your code repository is important. Backing up your code repository to an off-site location in a secure manner is imperative. Throughout our travels and experience utilizing the SVN code repository system, we have developed a quick bash script to export the entire SVN repository, encrypt it, compress it into an archive, and then ship it (over an encrypted network connection) to Amazon S3 storage.
We will be using the (familiar) s3sync Ruby script to do the actual transport to Amazon S3, which you can find here.
Note also that this script also keeps a local copy of the backups, taken each day, for a maximum of 7 days of retention. This might be redundant since all revisions are kept within SVN itself, but I thought it would provide an additional layer of backup redundancy. The script can be easily modified to only backup a single file every night, overwriting the older copy after every backup.
Here’s the script :
#!/bin/sh # SVN Off Site Backup script # www.stardothosting.com currentmonth=`date "+%Y-%m-%d %H:%M:%S"` threedays=`date -v-5d "+%Y-%m-%d"` todaysdate=`date "+%Y-%m-%d"` export AWS_ACCESS_KEY_ID="YOUR-S3-KEY-ID" export AWS_SECRET_ACCESS_KEY="YOUR-S3-ACCESS-KEY" echo "SVN Offsite Backup Log: " $currentmonth > /var/log/offsite-backup.log echo -e "--------------------------------------------" >> /var/log/offsite-backup.log echo -e "" >> /var/log/offsite-backup.log # Archive Repository Dump Files and remove files older than 7 days /usr/bin/find /subversion/svn_backups -type f -mtime +7 -delete # Backup SVN and encrypt it svnadmin dump /subversion/repo_name | /usr/bin/openssl enc -aes-256-cbc -pass pass:YOUR-ENCRYPTION-PASSWORD -e > /subversion/svn_backups/repo_name-backup-$todaysdate.enc #fyi to decrypt : #openssl aes-256-cbc -d -pass pass:YOUR-ENCRYPTION-PASSWORD -in repo_name-backup.enc -out decrypted.dump # Transfer the files to Amazon S3 Storage via HTTPS /usr/local/bin/ruby /usr/local/bin/s3sync/s3sync.rb --ssl -v --delete -r /subversion/svn_backups S3_BACKUPS:svn/svnbackup >> /var/log/offsite-backup.log 2>&1 if [ "$?" -eq 1 ] then echo -e "***SVN OFFSITE BACKUP JOB, THERE WERE ERRORS***" >> /var/log/offsite-backup.log 2>&1 cat /var/log/offsite-backup.log | mail -s "SVN Offsite Backup Job failed" email@example.com exit 1 else echo -e "Script Completed Successfully!" >> /var/log/offsite-backup.log 2>&1 cat /var/log/offsite-backup.log | mail -s "SVN Offsite Backup Job Completed" firstname.lastname@example.org exit 0 fi
Note how I have provided an example , commented out within the script, on how you can go about decrypting the encrypted SVN dump file. You can also modify this script to back up to any offsite location, obviously. Just remove the s3sync related entries and replace with rsync or your preferred transport method.
I hope this makes your life easier!