我读了整个互联网,但不能这样做。需要在VDS(Ubuntu 14.04)上启动Sidekiq启动。我发现并使用了这个:
# /etc/init/sidekiq.conf - Sidekiq config
# This example config should work with Ubuntu 12.04+. It
# allows you to manage multiple Sidekiq instances with
# Upstart, Ubuntu's native service management tool.
#
# See workers.conf for how to manage all Sidekiq instances at once.
#
# Save this config as /etc/init/sidekiq.conf then manage sidekiq with:
# sudo start sidekiq index=0
# sudo stop sidekiq index=0
# sudo status sidekiq index=0
#
# Hack Upstart's reload command to 'quiet' Sidekiq:
#
# sudo reload sidekiq index=0
#
# or use the service command:
# sudo service sidekiq {start,stop,restart,status}
#
description "Sidekiq Background Worker"
start on startup
#start on runlevel [2345]
stop on runlevel [06]
#start on startup
# change to match your deployment user
setuid me
setgid me
env HOME=/home/me
respawn
respawn limit 3 30
# TERM is sent by sidekiqctl when stopping sidekiq. Without declaring these as
# normal exit codes, it just respawns.
normal exit 0 TERM
# Older versions of Upstart might not support the reload command and need
# this commented out.
reload signal USR1
instance $index
script
# this script runs in /bin/sh by default
# respawn as bash so we can source in rbenv
exec /bin/bash <<'EOT'
# Pick your poison :) Or none if you're using a system wide installed Ruby.
# rbenv
# source /home/apps/.bash_profile
# OR
# source /home/apps/.profile
# OR system:
# source /etc/profile.d/rbenv.sh
#
rvm
source /usr/local/rvm/scripts/rvm
# Logs out to /var/log/upstart/sidekiq.log by default
cd /var/www/vk_c_watcher/code
exec bundle exec sidekiq -i ${index} -e production
EOT
end script
添加后,我可以使用start sidekiq app="/var/www/vk_c_watcher/code" index=0
启动Sidekiq。但是在重新启动时没有Sidekiq进程列表。
答案 0 :(得分:0)
this.set('data', [...]);
事件在系统启动时被触发,此时无法访问可写文件系统和网络,可能它确实尝试启动,但崩溃甚至无法记录此事。
稍后运行它,例如在运行级别2或某些自定义事件,当其他依赖项已启动时会触发(redis,您的数据库等)
同时注释掉 this.data=[...];
,这不是命令,而是下一行startup
的标签。
答案 1 :(得分:0)
感谢Mike Perham的帮助。我只是使用了错误的脚本。随着this script Sidekiq在启动时启动。