O script iniciante do serviço Unicorn lança "-su: bundle: command not found"

Recentemente, criei um VPS no DigitalOcean para hospedar um aplicativo de trilhos. Eu segui o guia deles para configurar o Unicorn com meu aplicativo.https://www.digitalocean.com/community/tutorials/how-to-deploy-a-rails-app-with-unicorn-and-nginx-on-ubuntu-14-04

Ocorreu um problema ao executarsudo service unicorn_appxyz start. O erro fornecido foi-su: bundle: command not found

Rastreei o script init.d e colei o comando de inicialização do servidor avaliado no terminal e ele funciona bem quando executado sob o usuárioJoe (o usuário em que o rbenv está instalado e o proprietário do aplicativo). O comando avaliado é

su - joe -c cd /home/joe/appxyz && bundle exec unicorn -c config/unicorn.rb -E production -D

Eu então sudo su - emraiz usuário e correuservice unicorn_appxyz start o erro foi obviamente o mesmo. Em seguida, executei o comando avaliado em root e ele retornou com este erro

The program 'bundle' is currently not installed. You can install it by typing:
apt-get install bundler

Parece que o script não está mudando de usuário? Provavelmente, a causa do unicórnio não iniciar quando eu inicializar o meu VPS.

O script inicial do unicórnio completo está aqui:

#!/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

Mais informações relacionadas

aqui estão os caminhos para ruby, rails e bundler no usuário joe. Na raiz, eles não são encontrados.

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

Faz sentido que o bundler não possa ser encontrado no usuário root, mas o comando upstart deve ter mudado para o usuário 'joe' para executar o comando bundle. Esta é a parte que eu não entendo.

questionAnswers(2)

yourAnswerToTheQuestion