Сценарий запуска службы Unicorn выдает «-su: bundle: команда не найдена»
Недавно я создал VPS на DigitalOcean для размещения приложения rails. Я следовал их руководству по настройке Unicorn с моим приложением.https://www.digitalocean.com/community/tutorials/how-to-deploy-a-rails-app-with-unicorn-and-nginx-on-ubuntu-14-04
Проблема возникла, когда я побежалsudo service unicorn_appxyz start
, Ошибка была-su: bundle: command not found
Я проследил сценарий init.d и вставил в терминал команду запуска оцененного сервера, и она отлично работает при выполнении под пользователемДжо (пользователь, который установил rbenv, и владелец приложения). Оцененная команда
su - joe -c cd /home/joe/appxyz && bundle exec unicorn -c config/unicorn.rb -E production -D
Я тогда sudo su - вкорень пользователь и побежалservice unicorn_appxyz start
ошибка была конечно же. Затем я выполнил оцененную команду под root, и она вернулась с этой ошибкой
The program 'bundle' is currently not installed. You can install it by typing:
apt-get install bundler
Кажется, скрипт не переключает пользователя? Это, вероятно, причина не запуска единорога, когда я загружаю свой VPS.
Полный скрипт выскочки единорога находится здесь:
#!/bin/sh
### BEGIN INIT INFO
# Provides: unicorn
# Required-Start: $all
# Required-Stop: $all
# Default-Start: 2 3 4 5
# Default-Stop: 0 1 6
# Short-Description: starts the unicorn app server
# Description: starts unicorn using start-stop-daemon
### END INIT INFO
set -e
USAGE="Usage: $0 <start|stop|restart|upgrade|rotate|force-stop>"
# app settings
USER="joe"
APP_NAME="appxyz"
APP_ROOT="/home/$USER/$APP_NAME"
ENV="production"
# environment settings
PATH="/home/$USER/.rbenv/shims:/home/$USER/.rbenv/bin:$PATH"
CMD="cd $APP_ROOT && bundle exec unicorn -c config/unicorn.rb -E $ENV -D"
PID="$APP_ROOT/shared/pids/unicorn.pid"
OLD_PID="$PID.oldbin"
# make sure the app exists
cd $APP_ROOT || exit 1
sig () {
test -s "$PID" && kill -$1 `cat $PID`
}
oldsig () {
test -s $OLD_PID && kill -$1 `cat $OLD_PID`
}
case $1 in
start)
sig 0 && echo >&2 "Already running" && exit 0
echo "Starting $APP_NAME"
su - $USER -c "$CMD"
;;
stop)
echo "Stopping $APP_NAME"
sig QUIT && exit 0
echo >&2 "Not running"
;;
force-stop)
echo "Force stopping $APP_NAME"
sig TERM && exit 0
echo >&2 "Not running"
;;
restart|reload|upgrade)
sig USR2 && echo "reloaded $APP_NAME" && exit 0
echo >&2 "Couldn't reload, starting '$CMD' instead"
$CMD
;;
rotate)
sig USR1 && echo rotated logs OK && exit 0
echo >&2 "Couldn't rotate logs" && exit 1
;;
*)
echo >&2 $USAGE
exit 1
;;
esac
Более подробная информация
Здесь приведены пути для ruby, rails и bundler под пользователем joe. Под рутом они не найдены.
joe@vps:~$ which ruby
/home/joe/.rbenv/shims/ruby
joe@vps:~$ which rails
/home/joe/.rbenv/shims/rails
joe@vps:~$ which bundle
/home/joe/.rbenv/shims/bundle
Имеет смысл, что пакет не может быть найден под пользователем root, но команда upstart должна была переключиться на пользователя 'joe', чтобы запустить команду bundle. Это та часть, которую я не понимаю.