いくつかのシェル スクリプトを開発しており、簡単なログ記録方法を追加したいと考えています。しかし、これまで作成された関数は、最初のログ行のみを出力します。どこに問題があるのか 理解できないため、ひどい頭痛がします
ロギング関数は、開発と理解が非常に簡単です。
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
. ロガーを使用し、現在のスクリプトのフォルダーにあるファイルに書き込むようにシェル関数を適応させることは可能ですか?