Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/marcusg/pg_backup
Create, restore, download and upload postgres dumps locally and on remote servers using capistrano
https://github.com/marcusg/pg_backup
capistrano database dump dumps postgresql rails restore restoring-postgres-dumps ruby sync synchronization
Last synced: about 2 months ago
JSON representation
Create, restore, download and upload postgres dumps locally and on remote servers using capistrano
- Host: GitHub
- URL: https://github.com/marcusg/pg_backup
- Owner: marcusg
- License: mit
- Created: 2015-09-21T15:32:38.000Z (over 9 years ago)
- Default Branch: master
- Last Pushed: 2022-12-21T14:27:59.000Z (about 2 years ago)
- Last Synced: 2024-04-26T01:02:01.131Z (8 months ago)
- Topics: capistrano, database, dump, dumps, postgresql, rails, restore, restoring-postgres-dumps, ruby, sync, synchronization
- Language: Ruby
- Homepage: https://github.com/marcusg/pg_backup
- Size: 31.3 KB
- Stars: 5
- Watchers: 1
- Forks: 3
- Open Issues: 5
-
Metadata Files:
- Readme: README.md
- License: LICENSE.txt
Awesome Lists containing this project
README
# pg_backup
## create and restore postgres dumps with capistrano
[![Gem Version](https://badge.fury.io/rb/pg_backup.svg)](http://badge.fury.io/rb/pg_backup)
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``` and ```pg_restore``` binaries## Installation
Add this line to your application's Gemfile:
```ruby
# 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```
```ruby
# Capfile
require "pg_backup/integration/capistrano"
```
this adds some capistrano tasks
```
cap pg_backup:dump:create # creates remote dump (from remote db) in remote dir
cap pg_backup:dump:load # imports latest remote dump into remote db
cap pg_backup:dump:download # downloads latest remote dump to local dir
cap pg_backup:dump:upload # uploads latest local dump to remote dir
cap 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).
```ruby
# staging.rb
set :environment, 'staging'
```To overwrite dump directories in capistrano, place something like this in your ```deploy.rb``` or ```.rb```
```ruby
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```
```ruby
# 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
1. Fork it ( https://github.com/marcusg/pg_backup/fork )
2. Create your feature branch (`git checkout -b my-new-feature`)
3. Commit your changes (`git commit -am 'Add some feature'`)
4. Push to the branch (`git push origin my-new-feature`)
5. Create a new Pull Request