Obter o mysql para iniciar automaticamente na inicialização

1

Eu percebo que há muitas perguntas por aqui para responder a esse problema - mas nenhuma parece funcionar para mim até agora.

Eu tentei:

sudo update-rc.d mysql defaults

Isso resultou em um erro de localidade, que corrigi com Como faço para corrigir meu problema de localidade? alterando /etc/environment

LC_ALL=en_US.UTF-8
LANG=en_US.UTF-8

Agora, ao tentar update-rc.d de novo, recebo:

update-rc.d: warning: /etc/init.d/mysql missing LSB information
update-rc.d: see <http://wiki.debian.org/LSBInitScripts>
 System start/stop links for /etc/init.d/mysql already exist.

Encontrei uma sugestão no link para usar:

user@computer:/etc/init.d$ sudo update-rc.d -f mystartupscript remove
user@computer:/etc/init.d$ sudo update-rc.d mystartupscript defaults
user@computer:/etc/init.d$ sudo chmod +x ./mystartupscript

Mas eu corro o risco de quebrar a implementação do meu mysql aqui? Está em um servidor de produção, então não posso simplesmente experimentá-lo e, de repente, não conseguir iniciar o mysql novamente.

No final, o servidor mysql precisa ser executado na inicialização. Tivemos algumas reinicializações de servidores vindas do host, e toda vez que esse é o caso, o banco de dados não é iniciado e as páginas hospedadas permanecem paradas até que o mysql seja iniciado manualmente.

Editar: /etc/init.d/mysql contents

#!/bin/sh -e
# upstart-job
#
# Symlink target for initscripts that have been converted to Upstart.

set -e

INITSCRIPT="$(basename "$0")"
JOB="${INITSCRIPT%.sh}"

if [ "$JOB" = "upstart-job" ]; then
    if [ -z "$1" ]; then
        echo "Usage: upstart-job JOB COMMAND" 1>&2
        exit 1
    fi

    JOB="$1"
    INITSCRIPT="$1"
    shift
else
    if [ -z "$1" ]; then
        echo "Usage: $0 COMMAND" 1>&2
        exit 1
    fi
fi

COMMAND="$1"
shift


if [ -z "$DPKG_MAINTSCRIPT_PACKAGE" ]; then
        ECHO=echo
else
        ECHO=:
fi

$ECHO "Rather than invoking init scripts through /etc/init.d, use the service(8)"
$ECHO "utility, e.g. service $INITSCRIPT $COMMAND"

# Only check if jobs are disabled if the currently _running_ version of
# Upstart (which may be older than the latest _installed_ version)
# supports such a query.
#
# This check is necessary to handle the scenario when upgrading from a
# release without the 'show-config' command (introduced in
# Upstart for Ubuntu version 0.9.7) since without this check, all
# installed packages with associated Upstart jobs would be considered
# disabled.
#
# Once Upstart can maintain state on re-exec, this change can be
# dropped (since the currently running version of Upstart will always
# match the latest installed version).

UPSTART_VERSION_RUNNING=$(initctl version|awk '{print $3}'|tr -d ')')

if dpkg --compare-versions "$UPSTART_VERSION_RUNNING" ge 0.9.7
then
    initctl show-config -e "$JOB"|grep -q '^  start on' || DISABLED=1
fi

case $COMMAND in
status)
    $ECHO
    $ECHO "Since the script you are attempting to invoke has been converted to an"
    $ECHO "Upstart job, you may also use the $COMMAND(8) utility, e.g. $COMMAND $JOB"
    $COMMAND "$JOB"
    ;;
start|stop)
    $ECHO
    $ECHO "Since the script you are attempting to invoke has been converted to an"
    $ECHO "Upstart job, you may also use the $COMMAND(8) utility, e.g. $COMMAND $JOB"
    if status "$JOB" 2>/dev/null | grep -q ' start/'; then
        RUNNING=1
    fi
    if [ -z "$RUNNING" ] && [ "$COMMAND" = "stop" ]; then
        exit 0
    elif [ -n "$RUNNING" ] && [ "$COMMAND" = "start" ]; then
        exit 0
    elif [ -n "$DISABLED" ] && [ "$COMMAND" = "start" ]; then
        exit 0
    fi
    $COMMAND "$JOB"
    ;;
restart)
    $ECHO
    $ECHO "Since the script you are attempting to invoke has been converted to an"
    $ECHO "Upstart job, you may also use the stop(8) and then start(8) utilities,"
    $ECHO "e.g. stop $JOB ; start $JOB. The restart(8) utility is also available."
    if status "$JOB" 2>/dev/null | grep -q ' start/'; then
        RUNNING=1
    fi
    if [ -n "$RUNNING" ] ; then
        stop "$JOB"
    fi
    # If the job is disabled and is not currently running, the job is
    # not restarted. However, if the job is disabled but has been forced into the
    # running state, we *do* stop and restart it since this is expected behaviour
    # for the admin who forced the start.
    if [ -n "$DISABLED" ] && [ -z "$RUNNING" ]; then
        exit 0
    fi
    start "$JOB"
    ;;
reload|force-reload)
    $ECHO
    $ECHO "Since the script you are attempting to invoke has been converted to an"
    $ECHO "Upstart job, you may also use the reload(8) utility, e.g. reload $JOB"
    reload "$JOB"
    ;;
*)
    $ECHO
    $ECHO "The script you are attempting to invoke has been converted to an Upstart" 1>&2
    $ECHO "job, but $COMMAND is not supported for Upstart jobs." 1>&2
    exit 1
esac
    
por Katai 25.08.2015 / 16:41

2 respostas

0

% bl0ck_qu0te%

Improvável. Ele não entrará no seu caminho para iniciar manualmente o MySQL de qualquer maneira, se falhar, tudo continuará o mesmo para você: não será possível iniciar automaticamente, mas iniciar manualmente ainda será possível.

Isso embora ...

% bl0ck_qu0te%

... me faz acreditar que já havia um início / parada para o início automático. Isso também me faria acreditar que você tem algum tipo de problema com a inicialização automática e a alteração pode não resolver o problema (se houver).

Você pode ter certeza de que não há avisos nos logs dentro de / var / log / syslog (provavelmente syslog) apontando para problemas com o início automático do mysql antes de alterá-lo. Porque se houver, será melhor consertar isso.

    
por Rinzwind 25.08.2015 / 16:56
0

Ok, mais duas coisas que você pode experimentar: Tente executar os comandos

user@computer:/etc/init.d$ sudo update-rc.d -f mysql remove
user@computer:/etc/init.d$ sudo update-rc.d mysql defaults

e veja qual é o resultado. Deve haver um número de links simbólicos criados em /etc/rcX.d .

E, em segundo lugar, veja se há um arquivo /etc/init/mysql.override que configura a inicialização do mysql para manual para o upstart, o mais moderno sistema de inicialização do Ubuntu.

    
por BubuIIC 25.08.2015 / 17:32