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.