为什么 ENV["HOME"] 在我的 rake 任务中为 nil?

Why is ENV["HOME"] nil in my rake task?

我有一个从控制器调用的 rake 任务——实际上控制器调用了一个 bash 脚本,它调用了一个 rake 任务。我们这样做是为了让工作人员可以请求数据库导入,这会重新导入数据并重新启动应用程序。

在命令行下,它有效。 ENV['HOME'] 已设置。

然而,当我们通过控制器 -> bash 脚本调用它时,rake 任务声称它为 nil。

那么,这可能是什么原因造成的? $HOME 不应该一直可见吗?

更新:

控制器(通过 unicorn 网络服务器)像这样调用 bash 脚本:system("#{Rails.root}/lib/cron/manual_digest.bash") 在被调用的 bash 脚本中,我 运行 export -p 并得到:

declare -x BUNDLE_BIN_PATH="/usr/local/lib/ruby/gems/2.1.0/gems/bundler-1.5.3/bin/bundle"
declare -x BUNDLE_GEMFILE="/var/www/ma_staging/releases/20150319193546/Gemfile"
declare -x BUNDLE_ORIG_MANPATH="/var/www/ma_staging/shared/bundle/ruby/2.1.0/gems/unicorn-4.8.3/man"
declare -x GEM_HOME="/var/www/ma_staging/shared/bundle/ruby/2.1.0"
declare -x GEM_PATH=""
declare -x LANG="en_US.UTF-8"
declare -x MANPATH="/var/www/ma_staging/shared/bundle/ruby/2.1.0/gems/unicorn-4.8.3/man"
declare -x OLDPWD="/var/www/ma_staging/current"
declare -x OLD_PID="/var/www/ma_staging/shared/pids/unicorn.pid.oldbin"
declare -x PATH="/var/www/ma_staging/shared/bundle/ruby/2.1.0/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/games"
declare -x PID="/var/www/ma_staging/shared/pids/unicorn.pid"
declare -x PWD="/home/deploy/ma_staging/current"
declare -x RACK_ENV="staging"
declare -x RAILS_ENV="staging"
declare -x RUBYLIB="/usr/local/lib/ruby/gems/2.1.0/gems/bundler-1.5.3/lib"
declare -x RUBYOPT="-rbundler/setup"
declare -x SHLVL="2"
declare -x TERM="xterm-256color"
declare -x UNICORN_FD="12,13"
declare -x _ORIGINAL_GEM_PATH=""

运行 通过 rails 控制台执行相同的命令:

export BUNDLE_BIN_PATH='/usr/local/lib/ruby/gems/2.1.0/gems/bundler-1.5.3/bin/bundle'
export BUNDLE_GEMFILE='/var/www/ma_staging/releases/20150319193546/Gemfile'
export BUNDLE_ORIG_MANPATH='/var/www/ma_staging/shared/bundle/ruby/2.1.0/gems/unicorn-4.8.3/man'
export COLUMNS='213'
export GEM_HOME='/var/www/ma_staging/shared/bundle/ruby/2.1.0'
export GEM_PATH=''
export HOME='/home/deploy'
export LANG='en_US.UTF-8'
export LESSCLOSE='/usr/bin/lesspipe %s %s'
export LESSOPEN='| /usr/bin/lesspipe %s'
export LINES='50'
export LOGNAME='deploy'
export MAIL='/var/mail/deploy'
export MANPATH='/var/www/ma_staging/shared/bundle/ruby/2.1.0/gems/unicorn-4.8.3/man'
export OLDPWD='/home/deploy/ma_staging/current/lib'
export PATH='/var/www/ma_staging/shared/bundle/ruby/2.1.0/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/games'
export PS1='\u:\W$ '
export PWD='/home/deploy/ma_staging/current'
export RAILS_ENV='staging'
export RUBYLIB='/usr/local/lib/ruby/gems/2.1.0/gems/bundler-1.5.3/lib'
export RUBYOPT='-rbundler/setup'
export SHELL='/bin/bash'
export SHLVL='1'
export SSH_AUTH_SOCK='/tmp/ssh-jkdbX19657/agent.19627'
export SSH_CLIENT='68.82.90.217 38992 22'
export SSH_CONNECTION='55.55.55.55 3322 55.55.55.55 22'
export SSH_TTY='/dev/pts/0'
export TERM='xterm'
export USER='deploy'
export _='/usr/local/bin/bundle'
export _ORIGINAL_GEM_PATH=''

我调查了 "restricted shells" 但这并不能完全解释我所看到的,缺少变量。我还研究了 "subshells"(因为第一个输出是 SHLVL=2),但这也没有具体解释这种行为。

我正在寻找一些文档或某处说 "when you do X, the variables for $HOME and $USER are not set because Z"

的东西

我怀疑 unicorn 有什么问题,但没有找到任何东西来解释为什么这些变量会是空的。

尝试将 echo "USER: $USER" 添加到您的 bash 脚本以查看 运行 下的用户控制器。可以在没有主目录的情况下创建用户,所以这可能是您 运行 喜欢的。例如,Apache www 服务器的用户 apache 没有主目录。

您也可以在 bash 脚本中设置环境。如果未设置 $HOME,您可以将其设置为 /tmp??

虽然 运行宁 rake 任务虽然控制器是个坏主意,但这仍然是你可以 运行 它并访问你所有环境的方法。变量。试一试

system "/bin/bash -l -c 'cd #{Rails.root.to_s} && RAILS_ENV=production bundle exec rake task_namespace:it_might_work --silent'" 

此外,如果上述操作失败,您可以将协议传递给 rake 任务。参考 How to pass command line arguments to a rake task

顺便说一句,我强烈建议将此 rake 任务作为后台脚本。使用它 sidekiqdelayed_job

好的,事实证明问题出在 unicorn 的启动方式和我们的 suoders 配置文件上,该文件配置错误。我担心这是一些错误 - 不,只是我们这边的配置错误。