Não é possível iniciar um serviço ZNC

3

Eu tento iniciar o ZNC usando o seguinte comando

service znc start

Eu recebo este erro

Starting znc: /usr/bin/dirname: extra operand '2>&1.pid'
Try '/usr/bin/dirname --help' for more information.
                                                           [FAILED]

É assim que o script init.d se parece

exec=/usr/bin/znc
prog=znc
config=/var/lib/znc
runas=znc

lockfile=/var/lock/subsys/$prog

start() {
[ -x $exec ] || exit 5
echo -n $"Starting $prog: "
# if not running, start it up here, usually something like "daemon $exec"
daemon --user $runas "$exec -d $config >/dev/null 2>&1"
# If you're reckless with your system, comment the line above and
# uncomment this one below... I just don't get it why
#daemon "$exec -r -d $config >/dev/null 2>&1"
retval=$?
echo
[ $retval -eq 0 ] && touch $lockfile
return $retval
}

Alguém sabe o que causaria isso.

Estou correndo centos

    
por totalitarian 30.11.2014 / 00:02

3 respostas

4

Eu criei um exemplo de script de inicialização com base no código da sua pergunta e determinei que você precisa alterar uma linha movendo as aspas duplas do final para o meio:

daemon --user $runas "$exec" -d $config >/dev/null 2>&1

A função daemon() em /etc/init.d/functions examina o primeiro parâmetro não-argumento, retira o caminho do programa para o nome da base e usa-o para derivar o arquivo de bloqueio PID. Ao (erroneamente) citar a string inteira, o arquivo PID está incorretamente determinado a ser 2>&1.pid , conforme evidenciado pelo seu erro.

A linha de código, conforme mostrada aqui, ainda será interrompida indefinidamente, se o programa ZNC não se tornar independente e entrar no segundo plano. Eu não tenho ZNC, então eu não posso testar esta parte, mas dado que o utilitário daemon CentOS não oferece nenhuma opção para o fundo de uma tarefa, eu espero que este requisito básico tenha sido endereçado dentro do próprio ZNC.

    
por 29.01.2015 / 00:42
0

Supondo que você já criou uma nova conta de usuário

sudo useradd --system --shell /sbin/nologin --comment "Account to run ZNC daemon" --user-group znc

E você já fez um arquivo de configuração:

Seu script init.d no CentOS deve ficar assim:

#!/bin/sh
#
# znc - Advanced IRC Bouncer INIT script #
# description: An Advanced IRC bouncer INIT script for
# Source function library.
. /etc/rc.d/init.d/functions

exec=/usr/bin/znc
prog=znc
config=/var/lib/znc
runas=znc

lockfile=/var/lock/subsys/$prog

start() {
    [ -x $exec ] || exit 5
    echo -n $"Starting $prog: "
    # if not running, start it up here, usually something like "daemon $exec"
    daemon --user $runas "$exec -d $config >/dev/null 2>&1"
    # If you're reckless with your system, comment the line above and
    # uncomment this one below... I just don't get it why
    # daemon "$exec -r -d $config >/dev/null 2>&1"
    retval=$?
    echo
    [ $retval -eq 0 ] && touch $lockfile
    return $retval
}

stop() {
    echo -n $"Stopping $prog: "
    # stop it here, often "killproc $prog"
    killproc $prog -TERM
    retval=$?
    echo
    [ $retval -eq 0 ] && rm -f $lockfile
    return $retval
}

reload() {
    echo -n $"Reloading $prog: "
    # stop it here, often "killproc $prog"
    killproc $prog -HUP
    retval=$?
    echo
}

restart() {
    stop
    start
}

rh_status() {
    # run checks to determine if the service is running or use generic status
    status $prog
}

rh_status_q() {
    rh_status >/dev/null 2>&1
}

case "$1" in
    start)
        rh_status_q && exit 0
        $1
        ;;
    stop)
        rh_status_q || exit 0
        $1
        ;;
    restart)
        $1
        ;;
    reload)
        rh_status_q || exit 7
        $1
        ;;
    status)
        rh_status
        ;;
    condrestart|try-restart)
        rh_status_q || exit 0
        restart
        ;;
    *)
        echo $"Usage: $0 {start|stop|status|reload|restart|condrestart|try-restart}"
        exit 2
esac
exit $?

Certifique-se de chmod +x caso contrário você poderia usar o crontab simplesmente adicionando

*/10 * * * *   /usr/bin/znc >/dev/null 2>&1

para o seu crontab ( crontab -e )

Substituindo 10 por um valor mais baixo para uma verificação mais agressiva

    
por 02.02.2015 / 01:28
0

daemon --user $runas --check $exec "$exec -d $config >/dev/null 2>&1" . Acabei de adicionar --check $exec . A função daemon não conseguiu fazer com que znc de "$exec -d $config >/dev/null 2>&1" criasse um arquivo pid como /var/run/znc.pid , se receber ${1##*/} , isso é avaliado como "null 2 > & 1'.O --check $exec garante que ele receba certo.
Ou você pode passar pidfile=/var/run/$(basename $exec).pid daemon --user $runas --pidfile $pidfile "$exec -d $config >/dev/null 2>&1"

Se a coisa toda não for citada como "$ exec -d $ config > / dev / null 2 > & 1", o stdout e stderr da função 'daemon' serão redirecionados e qualquer mensagem de saída ou erro de 'daemon 'função não irá aparecer durante o início. Deve gritar quando precisar. Não deveria ser calado. Quando citada, é passada como '$ *' para a função daemon, de modo que o stdout e stderr do $ exec sejam corretamente redirecionados. Citando $ exec sozinho não faz nada a menos que tenha espaço em branco em seu nome ou caminho.

Os daemons do sistema não precisam ser redirecionados para / dev / null, porque eles fecham todos os FDs abertos e abrem / dev / null em 0.1 e 2 e se separam do terminal e usam logs para saída. Aqui eu acho que o 'znc' precisa de redirecionamento de E / S porque não faz o redirecionamento em si.

    
por 02.02.2015 / 07:19