A rails plugin to backup Mysql or PostgreSQL to a cloud storage provider. You’re looking at a monthly spend of four cents. So pony up you cheap bastard, and store your backups offsite.
A grandfather style system is used to decide what backups to keep copies of:
-
all backups from the past 24 hours
-
one backup per day for the past week
-
one backup per week forever
Depending on your tolerance for data loss you should be running a backup at least once a day, probably more.
Add the following to your project Gemfile
gem "db2fog"
Add the following to config/initializers/db2fog.rb
In general, you can use any configuration options supported by Fog::Storage.new, plus the :directory option. If fog adds support for extra providers they should work with just a config change to Db2Fog.
DB2Fog.config = { :aws_access_key_id => 'yourkey', :aws_secret_access_key => 'yoursecretkey', :directory => 'bucket-name', :provider => 'AWS', :region => 'region' }
DB2Fog.config = { :rackspace_username => 'username', :rackspace_api_key => 'api key', :directory => 'bucket-name', :provider => 'Rackspace' }
DB2Fog.config = { :directory => 'bucket-name', :local_root => Rails.root.to_s + '/db/backups', :provider => 'Local' }
Database adaptors may support further configuration via the :database_options hash.
DB2Fog.config = { :directory => 'bucket-name', :local_root => Rails.root.to_s + '/db/backups', :provider => 'Local', :database_options => { :pg_version => 8 } }
Supported database options:
pg_version 8 or 9
The major version of PostgreSQL installed on the server. Defaults to 9.
# Add to your crontab or whatever rake db2fog:backup:full # Handy tasks rake db2fog:restore # You should be testing this regularly rake db2fog:clean # Clean up old backups - cron this
If you want to trigger backups from ruby (say, from a delayed job) you can do this:
DB2Fog.new.backup DB2Fog.new.clean
This is pure so ruby should run on most ruby VMs. I develop on MRI 1.9.2.
This will only work with rails 3. Supporting earlier versions is more complication than I feel like handling at the moment.
Specs are a little weak and mysql based. This code is bit hackish but is being used by quite a few people.
This is a fork of Xavier Shay’s db2s3 gem. It worked perfectly, but only supported Amazon S3 within US-east. By switching the dependency to using fog this now supports all S3 regions and multiple storage providers
Xavier’s original gem is available at github.com/xaviershay/db2s3
Xavier quotes the following example as inspiration:
github.com/pauldowman/blog_code_examples/tree/master/mysql_s3_backup