所以这个问题并不常见,因为到目前为止,我可以收集很多关于它的问题,但仍然无法自己解决这个问题
我有以下任务:
namespace :sidekiq do
task :start do
on roles(:app), in: :sequence, wait: 5 do
within release_path do
as :deploy do
with rails_env: fetch(:rails_env) do
execute :bundle, "exec sidekiq -e production -C ./config/sidekiq.yml -L ./log/sidekiq.log -d"
end
end
end
end
end
end
在主deploy.rb文件
中的namespace :deploy do ... end
内调用该任务
由于我的数据库信誉不足在〜/ .profile中存储在远程机器上,sidekiq无法运行(我试图将这些env变量放在〜/ .bashrc中等等......无论在找到的问题中可能存在或命名的点文件......都没有用)。我几乎做了任何可能的事情。
显然,如果我在远程计算机上运行 _very _ 相同的命令而不是通过capistrano,那么一切都运行良好。我最终得到了这个可怜的人:
task :start do
run_locally do
%x(ssh deploy@#{fetch(:application)} 'cd /var/www/#{fetch(:application)}/current && /home/xx/.rvm/bin/rvm 2.4.0 do bundle exec sidekiq -e production -C /var/www/#{fetch(:application)}/current/config/sidekiq.yaml -L /var/www/#{fetch(:application)}/current/log/sidekiq.log -d')
end
end
那就是说,如果对于那些使用常规execute :bundle, '...sidekiq startup cmd...'
而没有这类问题的人来说,这个错误听起来很明显;提前感谢大量的帮助
最佳
答案 0 :(得分:5)
如果你正在运行Ubuntu,你应该能够通过将它们放在~/.bashrc
的非常顶端来导出环境变量。
以下是运行Ubuntu 14.04的计算机的示例:
# ~deployer/.bashrc
export HELLO=world
为了演示,我有一个只打印环境的Capistrano任务:
task :env do
on roles(:all) do
execute "env"
end
end
当我运行它时,您可以看到HELLO=world
确实在预期的环境中:
$ cap production env
00:00 env
01 env
01 XDG_SESSION_ID=328
01 SHELL=/bin/bash
01 HELLO=world
01 SSH_CLIENT=xx.xx.xx.xx 16582 22
01 USER=deployer
01 SSH_AUTH_SOCK=/tmp/ssh-Twu5TDVnXb/agent.32558
01 MAIL=/var/mail/deployer
01 PATH=/home/deployer/.rbenv/shims:/home/deployer/.rbenv/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/b…
01 PWD=/home/deployer
01 LANG=en_US.UTF-8
01 RBENV_SHELL=bash
01 SHLVL=1
01 HOME=/home/deployer
01 LOGNAME=deployer
01 SSH_CONNECTION=xx.xx.xx.xx 16582 xx.xx.xx.xx 22
01 XDG_RUNTIME_DIR=/run/user/1000
01 _=/usr/bin/env
✔ 01 deployer@xx.xx.xx.xx 2.131s
对于其他与Capistrano兼容的方法将环境变量传递给Ruby进程,请参阅以下答案:https://stackoverflow.com/a/39628182/4625365
答案 1 :(得分:0)
之前我遇到过这个问题,因为capistrano使用非登录的非交互式shell。因此,在部署应用时,它根本不会触及.bash_rc或.profile文件,而且sidekiq无法访问您的环境变量。您可以找到有关in the Capistrano docs的更多信息。使用Unicorn,我不得不将我的env变种放在/etc/default/unicorn
中,所以我知道它们会被采购。根据您的使用情况,您应该找到部署应用时会触及的配置文件。