pg_backup
create and restore postgres dumps with capistrano
This gem adds rake tasks to your rails application for creating and restoring postgres dumps. The dumps are created with pg_dump
and restored with pg_restore
- these tools are included in a full postgres installation, but also available as standalone binaries (needed if your db is not located in the application server).
Requirements
- rails >= 3
- capistrano (optional)
- postgresql with
pg_dump
andpg_restore
binaries
Installation
Add this line to your application's Gemfile:
# Gemfile
gem 'pg_backup'
And then execute:
$ bundle
Usage
rake pg_backup:dump:create # create a dump from local db and save it locally
rake pg_backup:dump:load # import latest dump from local file into local db
If you want to create or load a dump file from a different directory or file name, use the PG_DUMP_DIR
and/or PG_DUMP_FILE
(relative to dump directory) env vars:
rake PG_DUMP_DIR=/my/dump/dir PG_DUMP_FILE=mydump.backup pg_backup:dump:create
rake PG_DUMP_DIR=/my/dump/dir PG_DUMP_FILE=mydump.backup pg_backup:dump:load
Capistrano integration
(https://github.com/capistrano/capistrano)
add to your Capfile
# Capfile
require "pg_backup/integration/capistrano"
this adds some capistrano tasks
cap <env> pg_backup:dump:create # creates remote dump (from remote db) in remote dir
cap <env> pg_backup:dump:load # imports latest remote dump into remote db
cap <env> pg_backup:dump:download # downloads latest remote dump to local dir
cap <env> pg_backup:dump:upload # uploads latest local dump to remote dir
cap <env> pg_backup:dump:list # shows list of dumps in remote dir
NOTE: Ensure environment variable set in capistrano files (needed for pg_backup to use correct database).
# staging.rb
set :environment, 'staging'
To overwrite dump directories in capistrano, place something like this in your deploy.rb
or <stage>.rb
set :pg_backup_local_dump_dir, '/my/dump/dir'
set :pg_backup_remote_dump_dir, '/my/dump/dir'
deploy-mate integration
(https://github.com/hanseventures/deploy-mate)
add to your Capfile
# Capfile
require "pg_backup/integration/deploy_mate"
Example usage
Create a dump on production server, download it, upload the dump to staging and load it into staging database
bundle exec cap production pg_backup:dump:create
bundle exec cap production pg_backup:dump:download
bundle exec cap staging pg_backup:dump:upload
bundle exec cap staging pg_backup:dump:load
PRO TIP: Use the simple sync task, which runs exactly the same commands:
bundle exec rake pg_backup:sync PG_DUMP_SOURCE=production PG_DUMP_TARGET=staging
Credits
https://gist.github.com/hopsoft/56ba6f55fe48ad7f8b90
Contributing
- Fork it ( https://github.com/marcusg/pg_backup/fork )
- Create your feature branch (
git checkout -b my-new-feature
) - Commit your changes (
git commit -am 'Add some feature'
) - Push to the branch (
git push origin my-new-feature
) - Create a new Pull Request