초기화 서비스를 통해 바큘라 디렉터를 시작할 수 없습니다


1

나는 데비안 8 시스템에서 bacula director를 설정하려고 시도 bacula-dir했지만 명령을 실행 하면 director가 올바르게 시작되지만 service bacula-director start그렇지 않습니다. sudo service bacula-director status서비스 예일을 시작한 후 실행

● 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.

active (exited)다른 bacula 데몬이 있기 때문에 의심스러운 것 같다 active (running). 또한 출력은 ps -A디렉터에게 프로세스를 표시하지 않지만 수동으로 시작하면 수행합니다.

bacula director의 서비스 정의는을 통해 director와 함께 설치된 init 스크립트입니다 (필자가 불가능하다고 생각합니다) apt-get. init 스크립트를 대체하기 위해 시스템화 된 단위 파일을 만드는 것 외에도 디렉터를 서비스로 시작하려면 어떻게해야합니까?

세균 감독의 초기화 스크립트

#! /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 <miquels@cistron.nl>.
#       Modified for Debian GNU/Linux by Ian Murdock <imurdock@gnu.ai.mit.edu>.
#       Customized for Bacula by Jose Luis Tallon <jltallon@adv-solutions.net>
#

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

bacula-dir /etc/bacula/bacula-dir.conf -dt -f -t?로 세균 구성을 확인할 수 있습니다 .
MUY Belgium

@MUYBelgium이 문제는 Bacula가 작동하지 않는다는 것이 아니라는 점을 다시 강조하겠습니다. (이 질문이 게시 된 달 동안 매주 백업에 사용되었습니다). 문제는 특히 Bacula를 초기화 서비스로 사용하는 것입니다 (bacula-dir을 사용하여 수동으로 시작하고 PID를 찾아서 중지하는 것이 아니라 여전히 PID를 사용하여 중지했습니다. 이 질문의 문제))
Trevor Giddings

이 명령은 Bacula director를 시작하지 않지만 구성을 테스트합니다. 만일을 위해서 ...
MUY Belgium

@MUYBelgium 알고 있습니다. 질문을 게시하기 전에 구성을 테스트했습니다. 그리고 다시, Bacula 는 해당 구성을 사용할 때 작동합니다 . 내가 겪고있는 문제는 init 스크립트를 사용하여 Bacula를 시작하는 데 엄청나게 구체적이었습니다.
Trevor Giddings

답변:


0
  1. DB 연결 확인 (config /etc/bacula/bacula-dir.conf의 카탈로그 섹션 참조)
  2. pkgs bacula-director & bacula-director-pgsql이 설치되어 있는지 확인하십시오

이 동작들을 좀 더 자세히 설명해 주시겠습니까? (즉, 그것들을 행동의 설명 으로 바꾸십시오 . ) 의견에 응답하지 마십시오. 명확하고 완전하게 답변을 편집 하십시오.
G-Man

둘 다 그렇습니다. 이 문제는 세균이 작동하지 않는다는 것이 아니라는 점을 다시 강조하겠습니다 (이 시점에서는 몇 달 동안 매주 백업을 위해 사용했습니다). 문제는 구체적으로 bacula를 서비스로 사용하는 것입니다 (bacula-dir을 사용하여 수동으로 시작하고 PID를 찾아서 중지시키는 것이 아니라 현재 PID해야합니다).
Trevor Giddings
당사 사이트를 사용함과 동시에 당사의 쿠키 정책개인정보 보호정책을 읽고 이해하였음을 인정하는 것으로 간주합니다.
Licensed under cc by-sa 3.0 with attribution required.