Heroku Rake任务没有运行shell脚本

时间:2016-07-14 15:51:34

标签: ruby-on-rails ruby shell heroku rake

我有这个Rake任务在本地工作:

namespace :backup_to_s3 do
  task run: :environment do
    puts "Started S3 backup"
    # create .pgpass so we don't have to enter the password
    entry = "#{ENV['RDS_DB_HOSTNAME']}:*:*:#{ENV['RDS_DB_SUPER_USERNAME']}:#{ENV['RDS_DB_SUPER_PASSWORD']}"
    `echo '#{entry}' > ~/.pgpass;
    chmod 0600 ~/.pgpass;
    bash backup_to_s3.sh`
    puts "Finished S3 backup"
  end
end

请注意,它会调用运行shell脚本。这是shell脚本:

#!/bin/bash

backupTime=`date +%Y%m%d-%H:%M`
S3Bucket=$S3_BUCKET_NAME
RDSHostname=$RDS_DB_HOSTNAME
RDSUsername=$RDS_DB_SUPER_USERNAME
RDSDatabaseName=$RDS_DB_NAME

pg_dump -Fc ${RDSDatabaseName} -h ${RDSHostname} -U ${RDSUsername} --no-password | gzip -9 | \
s3cmd put - s3://${S3Bucket}/postgres.${RDSDatabaseName}.dump.${backupTime}.gz

就像我说过这一切都在本地工作,puts日志记录语句有效。在Heroku上,任务运行,但puts语句立即执行,似乎表示系统调用且shell脚本未运行。

我很困惑为什么这不起作用!

更新7/15

我发现您可以设置PGPASSWORD环境变量,并避免创建.pgpass文件。 Rake任务仍未执行shell脚本。

1 个答案:

答案 0 :(得分:0)

Heroku没有为您提供传统的虚拟专用服务器,因此我不认为您有权写入主目录。在创建.pgpass文件时,您很可能会收到权限被拒绝错误。

尝试将您的文件放在rails项目的相对tmp/目录中。