Mam następującą pracę upstart:
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
Aby utworzyć folder w /var/run
, potrzebuję uprawnień roota. Jak mogę uruchomić niektóre części zadania upstart jako root, a sama usługa jako nieuprzywilejowany użytkownik?
start on starting posty
. Ale rejestrowanie jest znacznie lepsze niż moje.możesz użyć setguid w bloku skryptu i wpłynie to tylko na dany blok. Coś takiego:
źródło
setuid: not found
błąd.