Tenho o seguinte trabalho inicial:
description "posty api"
start on mysql
stop on shutdown
env RACK_ENV=production
setuid vmail
setgid vmail
chdir /opt/posty_api
pre-start script
mkdir -p /var/run/posty
chown -R vmail:root /var/run/posty
end script
exec /usr/local/bin/unicorn -D -c /opt/posty_api/unicorn.rb --env production >> /var/log/posty/upstart.log 2>&1
post-stop exec kill `cat /var/run/posty/unicorn.pid`
respawn
respawn limit 1 10
Para criar a pasta /var/run
, preciso de privilégios de root. Como posso executar algumas partes do trabalho inicial como root e o próprio serviço como usuário não privilegiado?
start on starting posty
. Mas o registro é muito melhor que o meu.você pode usar o setguid no bloco de scripts e isso afetará apenas o bloco especificado. Algo assim:
fonte
setuid: not found
erro.