Capistrano Redis-Serverを正常に起動しますが、ログインしても実行されていません。
-
13-12-2019 - |
質問
私は私のRedisサーバーを制御できるCapistranoスクリプトを持っています。これが問題のタスクです:
%w[start stop restart].each do |cmd|
desc "#{cmd}s redis-server"
task cmd, :roles => :app do
run "#{sudo} /etc/init.d/redis-server #{cmd}"
end
end
When I run this (deploying to a local vagrant VM) it says it's starts successfully:
> cap local redis:start
triggering load callbacks
* executing `local'
Deploying branch master
triggering start callbacks for `redis:start'
* executing `multistage:ensure'
* executing `redis:start'
* executing "sudo -p 'sudo password: ' /etc/init.d/redis-server start"
servers: ["192.168.33.10"]
Password:
[192.168.33.10] executing command
** [out :: 192.168.33.10] Starting redis-server:
** [out :: 192.168.33.10] redis-server.
command finished in 2054ms
.
しかしRedis-ServerがSSHに稼働していません。手動で起動した場合は機能します。
> sudo /etc/init.d/redis-server start
.
と同じ出力を得て、今回はプロセスが実行されたままである。
/var/log/redis/redis.log
のログを見るとファイルが空です。
私が間違っていることを考えていますか?私はこのような他のサービスを起動します(Nginx、Unicorn、MySQLなど)、それらは正常に機能しています。
解決
SSH接続が終了すると、Redisプロセスが終了していると思います。
nohup をスクリプトに追加してみてください。
run "#{sudo} nohup /etc/init.d/redis-server #{cmd}"
. 所属していません StackOverflow