- Verifique a conexão do db (consulte o catálogo de seção em config /etc/bacula/bacula-dir.conf)
- Verifique se você instalou o pkgs bacula-director & bacula-director-pgsql
Eu tenho tentado configurar o diretor bacula em um sistema debian 8 e descobri que executar o comando bacula-dir
inicia o diretor corretamente, mas service bacula-director start
não. executando sudo service bacula-director status
depois de iniciar os jogos de serviço
● bacula-director.service - LSB: Start Bacula Director at boot time
Loaded: loaded (/etc/init.d/bacula-director)
Active: active (exited) since Mon 2017-05-15 22:12:00 PDT; 16min ago
Process: 5614 ExecReload=/etc/init.d/bacula-director reload (code=exited, status=0/SUCCESS)
Process: 5418 ExecStart=/etc/init.d/bacula-director start (code=exited, status=0/SUCCESS)
May 15 22:12:00 debian-media systemd[1]: Starting LSB: Start Bacula Director at boot time...
May 15 22:12:00 debian-media bacula-director[5418]: Starting Bacula Director...: bacula-dir.
May 15 22:12:00 debian-media systemd[1]: Started LSB: Start Bacula Director at boot time.
May 15 22:13:04 debian-media systemd[1]: Reloading LSB: Start Bacula Director at boot time.
May 15 22:13:04 debian-media bacula-director[5614]: Reloading Bacula Director...: bacula-dir
May 15 22:13:04 debian-media systemd[1]: Reloaded LSB: Start Bacula Director at boot time.
May 15 22:28:20 debian-media systemd[1]: Started LSB: Start Bacula Director at boot time.
O active (exited)
parece suspeito, já que os outros daemons bacula são active (running)
. Além disso, a saída de ps -A
não mostra um processo para o diretor, ao passo que, manualmente, ele é iniciado.
A definição de serviço do diretor bacula é um script de inicialização (que acho impenetrável) instalado com o diretor via apt-get
. Além de talvez criar um arquivo de unidade do systemd para substituir o script de inicialização, como posso iniciar o diretor como um serviço?
script de inicialização do diretor bacula
#! /bin/sh
### BEGIN INIT INFO
# Provides: bacula-director
# Required-Start: $remote_fs $syslog
# Should-Start: bacula-fd postgresql mysql
# Required-Stop: $remote_fs $syslog
# Should-Stop: bacula-fd postgresql mysql
# Default-Start: 2 3 4 5
# Default-Stop: 0 1 6
# Short-Description: Start Bacula Director at boot time
# Description: bacula-director is the daemon that supervises all the
# backup, restore, verify and archive operations. The
# system administrator uses the Bacula Director to schedule
# backups and to recover files.
### END INIT INFO
# bacula-director SysV init script for Bacula-Director.
#
# Written by Miquel van Smoorenburg <[email protected]>.
# Modified for Debian GNU/Linux by Ian Murdock <[email protected]>.
# Customized for Bacula by Jose Luis Tallon <[email protected]>
#
set -e
PATH=/sbin:/bin:/usr/sbin:/usr/bin
DAEMON=/usr/sbin/bacula-dir
NAME="bacula-dir"
PORT=9101
DESC="Bacula Director"
if [ ! -x $DAEMON ] ; then
echo "No bacula-director SQL package installed"
exit 0
fi
if [ -n "'getent services bacula-dir'" ]; then
PORT='getent services bacula-dir | awk '{ gsub("/tcp","",$2); print $2; }''
fi
PIDFILE=/var/run/bacula/$NAME.$PORT.pid
. /lib/lsb/init-functions
. /usr/share/bacula-common/common-functions.init
if [ -r /etc/default/$NAME ]; then
. /etc/default/$NAME
fi
CONFIG="${CONFIG:-/etc/bacula/$NAME.conf}"
create_var_run_dir
get_pid()
{
if [ -r "$1" ]; then pid="'cat $1'";
else pid=""; fi
}
kill_pid()
{
kill -$1 $2 2>/dev/null || true
}
# do_start()
do_start()
{
start-stop-daemon --start --quiet --pidfile $PIDFILE \
--oknodo --exec $DAEMON -- -c $CONFIG $ARGS
}
# do_stop()
do_stop()
{
start-stop-daemon --oknodo --stop --quiet --pidfile $PIDFILE \
--retry TERM/30/KILL/5 --exec $DAEMON -- -c $CONFIG $ARGS
}
########################################################################
case "$1" in
start)
if [ "$ENABLED" = "no" ]; then
log_failure_msg "Not starting $DESC: disabled via /etc/default/$NAME"
exit 0
fi
create_var_run_dir
log_daemon_msg "Starting $DESC..." "$NAME"
if do_start ; then
log_end_msg 0
else
log_end_msg 1
fi
;;
stop)
log_daemon_msg "Stopping $DESC..." "$NAME"
if do_stop ; then
log_end_msg 0
else
log_end_msg 1
fi
;;
reload)
log_daemon_msg "Reloading $DESC..." "$NAME"
get_pid $PIDFILE
if [ -n "$pid" ]; then kill_pid HUP $pid ;
else do_start ;
fi
;;
restart|force-reload)
$0 stop
$0 start
;;
status)
status_of_proc -p $PIDFILE $DAEMON $NAME
;;
*)
N=/etc/init.d/$NAME
# echo "Usage: $N {start|stop|restart|reload|force-reload}" >&2
echo "Usage: $N {start|stop|restart|reload|force-reload|status}" >&2
exit 1
;;
esac