1

いくつかのシェル スクリプトを開発しており、簡単なログ記録方法を追加したいと考えています。しかし、これまで作成された関数は、最初のログ行のみを出力します。どこに問題があるのか​​ 理解できないため、ひどい頭痛がします

ロギング関数は、開発と理解が非常に簡単です。

LOG_FILE="creation.log"

logit() 
{
    echo "[${USER}][`date`] - ${*}" >> ${LOG_FILE}
}

そして、スクリプトのいくつかの行。

    LOG_FILE="creation.log"

logit() 
{
    echo "[${USER}][`date`] - ${*}" >> ${LOG_FILE}
}

repImport()
{
    # création des repertoires pour les répertoires d'export.
    mkdir -p acharger
    mkdir -p archives

    logit "repImport correctement crée."
}

repExport()
{
    # création des repertoires pour les répertoires d'import.
    mkdir -p archives
    mkdir -p atraiter

    logit "repExport correctement crée."
}

array=(BNP_CB collection_XTL collection_QT sp xcl xtl pgi qnt visualr)

logit "Array généré"

REP_TEST="/tmp/jorge/modules"
REP=${REP_TEST}        # Descomentar para hacer test.

REP_LIV_VX="/tmp/jorge/modules/"


# NOTE IMPORTANTE
#------------------
# Obligatoire créer avec l'user root le répertoire /home/pepsicash, après changer le propietaire pour cash --> root /> chown cash.mersi pepsicash/


# deuxième partir (répertoires pour les fichiers)
#----------------------------------------------------
echo "Création des répertoires pour les fichiers"
mkdir -p "${REP}""/journaux"    # originel: /home/pepsicash/journaux
mkdir -p "${REP}""/data"        # originel: /home/pepsicash/data

cd $REP/data            # originel: /home/pepsicash/data    
mkdir -p imports
mkdir -p exports
mkdir -p tmpcft

logit "Création des répertoires sur Exports"
cd exports
repExport
cd ..

logit "Création des répertoires sur Imports"
cd imports

for index in ${!array[*]}
do

    if [ $index -eq 0 ]; 
    then
        if [ -d ${array[$index]} ]; then
            logit "El répertoire ENCAISSEMENTS existe déjà."
        else
            logit "Le répertoire n'existe pas."
            mkdir -p ENCAISSEMENTS
            logit "Répertoire ENCAISSEMENTS crée correctement."
        fi

        cd ENCAISSEMENTS
        repImport
        logit "Répertoire ENCAISSEMENTS crée, CP -> BNP_CB "
        cd ..

        if [ -d ${array[$index]} ]; then
            logit "El répertoire IMPAYES existe déjà."
        else
            logit "Le répertoire n'existe pas."
            mkdir -p IMPAYES
            logit "Répertoire IMPAYES crée correctement."
        fi

        cd IMPAYES
        repImport
        logit "Répertoire ENCAISSEMENTS crée, CP -> BNP_CB "
        cd ..

        logit "Case particulier BNP_CB crée."

        continue
    fi

    if [ -d ${array[$index]} ]; then
        # Control will enter here if $DIRECTORY exists.
        logit "El répertoire existe déjà."
    else
        logit "Le répertoire n'existe pas."
        mkdir -p ${array[$index]}
        logit "Répertoire ${array[$index]} crée correctement."
    fi

    cd ${array[$index]}

    repImport
    cd ..
done

echo "Fin création des répertoires."

ログファイルには最初のlogit呼び出しのみが含まれます。メソッドへの他の呼び出しが機能しないのはなぜですか?

[JV07483S][Fri Aug 16 18:19:04 CEST 2013] - Array généré
[JV07483S][Fri Aug 16 18:19:30 CEST 2013] - Array généré

Webで検索すると、loggerコマンドを使用できることがわかりましたが、常に/var/ folder. ロガーを使用し、現在のスクリプトのフォルダーにあるファイルに書き込むようにシェル関数を適応させることは可能ですか?

4

2 に答える 2

1

コードを数回実行すると、次のような出力が得られますcreation.log

[jleffler][Fri Aug 16 13:53:56 PDT 2013] - Array généré
[jleffler][Fri Aug 16 13:53:56 PDT 2013] - Le répertoire n'existe pas.
[jleffler][Fri Aug 16 13:53:56 PDT 2013] - Répertoire ENCAISSEMENTS crée correctement.
[jleffler][Fri Aug 16 13:54:37 PDT 2013] - Array généré
[jleffler][Fri Aug 16 13:54:37 PDT 2013] - Le répertoire n'existe pas.
[jleffler][Fri Aug 16 13:54:37 PDT 2013] - Répertoire ENCAISSEMENTS crée correctement.
[jleffler][Fri Aug 16 13:54:44 PDT 2013] - Array généré
[jleffler][Fri Aug 16 13:54:44 PDT 2013] - Le répertoire n'existe pas.
[jleffler][Fri Aug 16 13:54:44 PDT 2013] - Répertoire ENCAISSEMENTS crée correctement.
[jleffler][Fri Aug 16 13:54:58 PDT 2013] - Array généré
[jleffler][Fri Aug 16 13:54:58 PDT 2013] - El répertoire ENCAISSEMENTS existe déjà.

最後の実行でmkdir BNP_CBは、コマンドを再度実行する前に実行しました。私は少しごまかしてcat $LOG_FILE、スクリプト内に配置しました:

#!/bin/bash

LOG_FILE="creation.log"

logit() 
{
    echo "[${USER}][`date`] - ${*}" >> ${LOG_FILE}
}

array=(BNP_CB cashcollection_EXTELIA cashcollection_QENAT espace excel extelia pgi qenat visualr)

logit "Array généré"

for index in ${!array[*]}
do
    if [ $index -eq 0 ];
    then
        if [ -d ${array[$index]} ]; then
            logit "El répertoire ENCAISSEMENTS existe déjà."
        else
            logit "Le répertoire n'existe pas."
            mkdir -p ENCAISSEMENTS
            logit "Répertoire ENCAISSEMENTS crée correctement."
        fi
    fi
done

cat $LOG_FILE

インデックス 0 のみを処理する場合に配列内のすべての項目を一覧表示する理由や、BNP_CB が存在しない場合に ENCAISSEMENTS を作成する理由などについて解決すべき問題がいくつかありますが、これらの問題はログに接しています。機能するか(私にとってはそうです)、そうでないか(あなたにとってはそうではありません)。

走るとどうなりますbash -x yourscript.shか?それは何が起こっているかを示していますか?

于 2013-08-16T20:59:37.240 に答える