Как автоматически отправлять Heroku pgbackups на S3 - PullRequest
4 голосов
/ 07 мая 2011

Мы используем великолепные резервные копии Heroku PG http://addons.heroku.com/pgbackups

В настоящее время я каждый день вручную загружаю резервные копии на свой компьютер, а затем загружаю их в свою учетную запись S3.Кто-нибудь знает, как настроить задание cron для автоматического создания резервной копии (ежедневно это нормально) и отправки ее непосредственно на мою учетную запись S3?

Ответы [ 3 ]

4 голосов
/ 16 августа 2012

Я исправил драгоценный камень, чтобы исправить системный вызов, упомянутый B Seven.Регулярное выражение, которое получило параметры базы данных, было повреждено, потому что новый DATABASE_URL для баз данных без общего доступа теперь содержит номер порта.

https://github.com/mokolabs/heroku_s3_backup

Если вы находитесь в стеке Cedar, то этопатч должен работать на вас.Но я использую Bamboo, и он не работает для меня из-за конфликта версий с pg_dump.Postgres - это версия 8.x для Bamboo, поэтому pg_dump не может выгрузить данные из новых не общих баз данных, потому что все они работают на Postgres версии 9.1.

Если мне удастся найти обходной путь дляСтек бамбука, я обновлю драгоценный камень и мой комментарий здесь.

3 голосов
/ 07 мая 2011

Если вы добавите это в lib / tasks и у вас будет запущен herkou надстройка cron:

namespace :heroku do
  desc "PostgreSQL database backups from Heroku to Amazon S3"
  task :backup => :environment do
    begin
      require 'right_aws'
      puts "[#{Time.now}] heroku:backup started"
      name = "#{ENV['APP_NAME']}-#{Time.now.strftime('%Y-%m-%d-%H%M%S')}.dump"
      db = ENV['DATABASE_URL'].match(/postgres:\/\/([^:]+):([^@]+)@([^\/]+)\/(.+)/)
      system "PGPASSWORD=#{db[2]} pg_dump -Fc -i --username=#{db[1]} --host=#{db[3]} #{db[4]} > tmp/#{name}"
      s3 = RightAws::S3.new(ENV['s3_access_key_id'], ENV['s3_secret_access_key'])
      bucket = s3.bucket("#{ENV['APP_NAME']}-heroku-backups", true, 'private')
      bucket.put(name, open("tmp/#{name}"))
      system "rm tmp/#{name}"
      puts "[#{Time.now}] heroku:backup complete"
    # rescue Exception => e
    #   require 'toadhopper'
    #   Toadhopper(ENV['hoptoad_key']).post!(e)
    end
  end
end

task :cron => :environment do
  Rake::Task['heroku:backup'].invoke
0 голосов
/ 13 июня 2018

ИМХО самый простой и быстрый (10 минут) способ - настроить heroku-db-backup-s3 buildpack. Нет необходимости в коде, только добавление пакета сборки и настройка некоторых переменных среды и одного перепланирования.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...