为什么 ENV[ "HOME" ] 在我的耙子任务中为零?



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

在命令行中,它是有效的。设置CCD_ 1。

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

那么,是什么原因导致了这种情况呢?$HOME不应该一直可见吗?

更新:

控制器(通过独角兽网络服务器)在被调用的bash脚本中调用一个bash脚本,比如:system("#{Rails.root}/lib/cron/manual_digest.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=''

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

我正在寻找一些文档或某个地方说"当你做X时,$HOME和$USER的变量没有设置,因为Z"

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

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

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

尽管通过控制器运行rake任务是个坏主意,但这仍然是运行它并访问所有env的方法。变量。试试

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

此外,若上述操作失败,您可以将警告传递给rake任务。请参阅如何将命令行参数传递给rake任务

顺便说一句,我强烈建议把这个rake任务作为背景脚本。使用ENV['HOME']0或delayed_job

ok,原来问题出在独角兽的启动方式和我们的suoders配置文件上,该文件配置错误。我担心这是一些错误——不,只是我们这边的配置错误。

最新更新