SaltStack - Journalisation
La journalisation est utilisée pour suivre les événements logiciels en cours d'exécution. Un événement est décrit par un message descriptif, qui peut éventuellement contenir des données variables. L'approche de la journalisation du sel est utilisée pour obtenir tous les problèmes auxquels vous pourriez être confronté. Vous pouvez vérifier avec des niveaux de journal spécifiques.
Paramètres de configuration
Laissez-nous comprendre les différents paramètres de configuration pour la journalisation, en détail.
FICHIER JOURNAL
Les enregistrements du journal Salt sont transmis via le fichier, qui contient le nom du chemin local ou l'emplacement réseau pour identification. Ce fichier est considéré comme le fichier journal.
log_file: /var/log/salt/master
Ici, le fichier dépendant du binaire est exécuté dans master. De même, vous pouvez également exécuter dans le serviteur, comme indiqué ci-dessous.
log_file: /var/log/salt/minion
Vous pouvez également utiliser une adresse distante. La syntaxe pour utiliser l'adresse distante est - <file | udp | tcp>: // <host | socketpath>: <port-if-required> / <log-facility>.
log_file: udp://loghost:port
Ici, la fonction de journalisation est par défaut LOG_USER.
LOG_LEVEL
Les niveaux de journal sont classés dans une valeur attribuée numériquement. La bibliothèque Python a défini la plupart des niveaux de journalisation par défaut. En plus de cela, Salt utilise plus de niveaux. Certains des niveaux sont expliqués ci-dessous.
log_level: error; level value is 40 - Il indique l'enregistrement de l'instruction de journal en cas d'erreur.
log_level: quiet; level value is 1000 - Il indique que rien ne doit être enregistré à ce niveau.
log_level: info; level value is 20 - Il indique les informations normales du journal.
log_level: warn; level value is 30 - Il indique l'enregistrement de l'instruction de journal à l'avertissement.
log_level: debug; level value is 10 - Informations utiles pour déboguer les implémentations salt et le code salt.
log_level: trace; level value is 5 - Informations de débogage de code plus détaillées.
LOG_LEVEL_LOGFILE
Il définit le niveau des messages à envoyer au fichier journal.
log_level_logfile: info
LOG_DATEFMT
Il définit le format de la date du journal. Par défaut, il est représenté par% Y-% m-% d% H:% M:% S.
log_datefmt_logfile: '%Y-%m-%d %H:%M:%S'
LOG_FMT_CONSOLE
Il définit le format de la console enregistrant les messages. Salt utilise une coutumeLogRecordattributs pour coloriser la sortie du journal de la console. Il suit la syntaxe suivante -
'%(colorlevel)s' # log level name colorized by level
'%(colorname)s' # colorized module name
'%(colorprocess)s' # colorized process number
'%(colormsg)s' # colorized messages name
LOG_FMT_LOGFILE
Il définit le format du fichier journal enregistrant les messages. La syntaxe de base est la suivante -
%(asctime)s,%(msecs)03d [%(name)-17s][%(levelname)-8s] %(message)s
LOG_GRANULAR_LEVELS
Ce niveau est utilisé pour contrôler plus spécifiquement les niveaux de journalisation.
log_granular_levels:
'salt': 'info'
'salt.modules': ‘trace'
Ici, la bibliothèque de sel principale au niveau 'info' définit le salt.modules pour se connecter au niveau de la trace.
Gestionnaire de journalisation externe
Salt utilise le gestionnaire de journaux externe LogStash et Sentry pour la journalisation. Comprenons-le en détail dans ce chapitre.
Gestionnaire LOGSTASH
LogStash est une source ouverte; pipeline de traitement de données sécurisé côté serveur. Considérons un simple gestionnaire de journalisation UDP dans Salt qui utilise LogStash.
Spécifiez les modifications suivantes dans le fichier maître Salt -
logstash_udp_handler:
host: 127.0.0.1
port: 9999
version: 1
msg_type: logstash
Ajoutez ensuite les modifications dans le fichier de configuration de Logstash -
input {
udp {
port ⇒ 9999
codec ⇒ json
}
}
Ici, UDP - est l'entrée qui doit avoir un format comme json_event, qui est ce que nous envoyons sur le fil.
Gestionnaire de journalisation SENTRY
Sentry est un suivi des erreurs en temps réel dans les déploiements de production et des informations pour reproduire et corriger les plantages. La configuration par défaut dans le fichier maître est définie ci-dessous.
sentry_handler:
dsn: https://pub-key:[email protected]/app-id
log_level: debug
Ici, le niveau de journalisation par défaut pour le gestionnaire de sentinelle est ERREUR, mais nous avons défini le débogage log_level sous la clé de configuration sentry_handler.