Eu tenho um script no Ubuntu 9.04 em init.d que configurei para ser executado no início com update-rc.d usando update-rc.d padrões init_test 99. Todos os links simbólicos estão lá e as permissões parecem esteja correto
-rwxr-xr-x 1 root root 642 2010-10-28 16:44 init_test
mike@xxxxxxxxxx:~$ find /etc -name S99* | grep init_test
find: /etc/rc5.d/S99init_test
find: /etc/rc4.d/S99init_test
find: /etc/rc2.d/S99init_test
find: /etc/rc3.d/S99init_test
O script é executado por meio de source e ./ sem problemas e se comporta corretamente. Aqui está a fonte do script:
#!/bin/bash
### BEGIN INIT INFO
# Provides: init test script
# Required-Start: $remote_fs $syslog
# Required-Stop: $remote_fs $syslog
# Default-Start: 2 3 4 5
# Default-Stop: 0 1 6
# Short-Description: Start daemon at boot time
# Description: Enable service provided by daemon.
### END INIT INFO
start() {
echo "hi"
echo "start called" >> /tmp/test.log
return
}
stop() {
echo "Stopping"
}
echo "Script called" >> /tmp/test.log
case "$1" in
start)
start
;;
stop)
stop
;;
*)
echo "Usage: {start|stop|restart}"
exit 1
;;
esac
exit $?
Quando a máquina é iniciada, não vejo "script chamado" ou "inicialização chamada" no test.log. Há algo óbvio que estou bagunçando?
Responder1
Eu descobri o que estava errado. Havia um script completamente não relacionado que estava sendo bloqueado na inicialização porque estava solicitando um pressionamento de tecla do usuário, o que parece paralisar todos os outros scripts de inicialização. Existe uma maneira de solucionar problemas como esse, como registrar quais scripts init.d são executados?