本番データベースがあり、そのスナップショットをステージングデータベースに定期的に取得したいと思います。
私はpgbackupsを使用してこれを行う方法を知っていますが、新しいHerokuPostgresフォーク関数を使用してこれを行う方法を誰かが知っているかどうか疑問に思いました。
本番データベースがあり、そのスナップショットをステージングデータベースに定期的に取得したいと思います。
私はpgbackupsを使用してこれを行う方法を知っていますが、新しいHerokuPostgresフォーク関数を使用してこれを行う方法を誰かが知っているかどうか疑問に思いました。
はい、あるアプリケーションDBから別のアプリケーションDBに直接フォークを作成できます。これを行うには、プライマリアプリケーションからDATABASE_URLの値を取得し、それを次のコマンドで使用します。
heroku addons:add heroku-postgresql:ronin --fork postgres://username:password@ec2.../database --app yourstagingapp
クレイグの答えに加えて、これがすべての仕事をするfreeformzによるスクリプトです。
app=${1}
db_type=${2:-ronin}
old_db=`heroku config -a ${app}-staging | grep ^HEROKU_POSTGRESQL | cut -d : -f 1 | sed s/_URL//`
heroku addons:add heroku-postgresql:${db_type} --fork `heroku config -a ${app} | grep ^DATABASE_URL | cut -d : -f 2-5` -a ${app}-staging
new_db=`heroku config -a ${app}-staging | grep ^HEROKU_POSTGRESQL | grep -v ${old_db} | cut -d : -f 1 | sed s/_URL//`
heroku pg:wait -a ${app}-staging
heroku pg:promote ${new_db} -a ${app}-staging
#Remove the old db
if [ ! -z "${old_db}" ]l; then
heroku addons:remove ${old_db} -a ${app}-staging --confirm ${app}-staging
fi