O script Upstart não funciona

1

Estou tentando criar meu próprio script que é executado na inicialização e interrompido no desligamento (referindo-se ao estilo de inicialização clássico do System-V), mas não funciona!

Eu criei este script ( /etc/init.d/mlogscript ):

#!/bin/bash
### BEGIN INIT INFO
# Provides:             logging down time and date of your start/shutdown behaviour
# Required-Start:       $all
# Required-Stop:        $all
# Default-Start:        2 3 4 5
# Default-Stop:         0 1 6
# Short-Description:    logs down your start/shutdown behaviour
# Description:          script for logging when you start or shutdown the operating system
### END INIT INFO
# Author: x

# log-file info
FILENAME="logscript.log"
FILEPATH="$HOME/myScripts/"

# other files
UPTIMEFILE=${FILEPATH}"LASTUPTIME.DONOTDELETE"

# fetch specific data
DATE='date +%m.%d.%Y'
CLOCK='date +%X'

case "$1" in
    start)
    if [ ! -e "${FILEPATH}${FILENAME}" ]; then
        echo "creating log-file"
        echo -ne "mLog: start/shutdown behaviour\n" >> "${FILEPATH}${FILENAME}"
        echo -e "-------------------------------\n" >> "${FILEPATH}${FILENAME}"
    fi
    echo -e '[' $DATE "]\nuser:\t" $USER "\nstart:\t" $CLOCK >> "${FILEPATH}${FILENAME}"

    # create/update uptime-file
    UPTIME=$(</proc/uptime)
    UPTIME=${UPTIME%%.*}
    echo -ne $UPTIME > $UPTIMEFILE

    echo "log-script started at" $DATE "."
        ;;
    stop)
    if [ -e "${FILEPATH}${FILENAME}" ]; then
        # get uptime from /proc/uptime
        UPTIME=$(</proc/uptime)
        UPTIME=${UPTIME%%.*}

        # 
        if [ -e "${UPTIMEFILE}" ]; then
            LASTUPTIME=$(head -n 1 "${UPTIMEFILE}")
            UPTIME='expr $UPTIME - $LASTUPTIME'
            echo $UPTIME
        fi

        SECONDS=$((UPTIME%60))
        MINUTES=$((UPTIME/60%60))
        HOURS=$((UPTIME/60/60%24))
        DAYS=$((UPTIME/60/60/24%365))
        YEAR=$((UPTIME/60/60/24/365))
        # write to file
        echo -ne "end:\t" $CLOCK "\nuptime:\tY" $YEAR ' D' $DAYS ' H' $HOURS ' M' $MINUTES ' S' $SECONDS "\n\n" >> "${FILEPATH}${FILENAME}"
        echo "log-script stopped"
    else
        echo "log-file doesn't exist"
    fi
        ;;
    restart)
    if [ -e "${FILEPATH}${FILENAME}" ]; then
        exec $(readlink -f "$0") stop
        $(readlink -f "$0") start
        echo -e "log-script restarted"
    fi
        ;;
    reset)
    echo -e "log-script reset"
    if [ -e "${FILEPATH}${FILENAME}" ]; then
        rm "${FILEPATH}${FILENAME}"
        exec $(readlink -f "$0") start
    fi
    ;;
esac
exit 0

Depois disso, defino o proprietário e o grupo do arquivo para "root" executando

sudo chown root:root /etc/init.d/mlogscript

Por último, mas não menos importante, criei os links simbólicos específicos do tempo de execução nas pastas rc [0-6] .d:

sudo update-rc.d mlogscript defaults 98

Depois que eu reiniciei meu sistema, nada acontece, por quê?

    
por neuronalbit 21.04.2014 / 11:52

1 resposta

0

  1. Abrir traço
  2. Pesquise por "Aplicativos de inicialização" e abra-o
  3. Clique no botão "Adicionar".
  4. A caixa de diálogo permite definir um nome, o comando a ser executado e comentários.
  5. Clique em "Adicionar" para salvar o comando na lista.

O Ubuntu irá então executar todos os comandos nesta lista durante a inicialização. Eu uso isso para executar um script de mudança de papel de parede por conta própria na inicialização, e ele provou ser confiável.

Acho que você deve estar sabendo disso, mas ainda assim, lembre-se de adicionar um & no final do comando para continuar executando o script em segundo plano e evitar depurações e frustrações desnecessárias.

Desculpe, mas não sei como fazer isso no terminal.

    
por udiboy1209 21.04.2014 / 13:40