Guest User

Untitled

a guest
Dec 10th, 2018
264
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
text 0.93 KB | None | 0 0
  1. namespace :heroku do
  2. desc "PostgreSQL database backups from Heroku to Amazon S3"
  3. task :backup => :environment do
  4. begin
  5. require 'right_aws'
  6. puts "[#{Time.now}] heroku:backup started"
  7. name = "#{ENV['APP_NAME']}-#{Time.now.strftime('%Y-%m-%d-%H%M%S')}.dump"
  8. db = ENV['DATABASE_URL'].match(/postgres:\/\/([^:]+):([^@]+)@([^\/]+)\/(.+)/)
  9. system "PGPASSWORD=#{db[2]} pg_dump -Fc --username=#{db[1]} --host=#{db[3]} #{db[4]} > tmp/#{name}"
  10. s3 = RightAws::S3.new(ENV['s3_access_key_id'], ENV['s3_secret_access_key'])
  11. bucket = s3.bucket("#{ENV['APP_NAME']}-heroku-backups", true, 'private')
  12. bucket.put(name, open("tmp/#{name}"))
  13. system "rm tmp/#{name}"
  14. puts "[#{Time.now}] heroku:backup complete"
  15. # rescue Exception => e
  16. # require 'toadhopper'
  17. # Toadhopper(ENV['hoptoad_key']).post!(e)
  18. end
  19. end
  20. end
  21.  
  22. task :cron => :environment do
  23. Rake::Task['heroku:backup'].invoke
  24. end
Add Comment
Please, Sign In to add comment