SaltStack - Protokollierung

Die Protokollierung wird verwendet, um die laufenden Softwareereignisse zu verfolgen. Ein Ereignis wird durch eine beschreibende Nachricht beschrieben, die optional variable Daten enthalten kann. Der Salzprotokollierungsansatz wird verwendet, um eventuelle Probleme zu beheben. Sie können mit bestimmten Protokollebenen auschecken.

Konfigurationseinstellungen

Lassen Sie uns die verschiedenen Konfigurationseinstellungen für die Protokollierung im Detail verstehen.

LOGDATEI

Salt-Log-Datensätze werden durch die Datei geleitet, die den lokalen Pfadnamen oder den Netzwerkspeicherort zur Identifizierung enthält. Diese Datei wird als Protokolldatei betrachtet.

log_file: /var/log/salt/master

Hier wird die Datei abhängig von der Binärdatei im Master ausgeführt. In ähnlicher Weise können Sie auch im Minion ausführen, was unten gezeigt wird.

log_file: /var/log/salt/minion

Sie können auch die Remote-Adresse verwenden. Die Syntax für die Verwendung der Remote-Adresse lautet - <file | udp | tcp>: // <host | socketpath>: <port-if-required> / <log-facility>.

log_file: udp://loghost:port

Hier ist die Log-Funktion standardmäßig LOG_USER.

LOG_LEVEL

Die Protokollebenen sind in einem numerisch zugewiesenen Wert angeordnet. Die Python-Bibliothek hat standardmäßig die meisten Protokollierungsstufen definiert. Darüber hinaus verwendet Salt einige weitere Ebenen. Einige der Ebenen werden unten erläutert.

  • log_level: error; level value is 40 - Es zeigt den fehlerhaften Protokollanweisungsdatensatz an.

  • log_level: quiet; level value is 1000 - Es zeigt an, dass auf dieser Ebene nichts protokolliert werden soll.

  • log_level: info; level value is 20 - Es zeigt die normalen Protokollinformationen an.

  • log_level: warn; level value is 30 - Es zeigt den Protokollanweisungsdatensatz bei Warnung an.

  • log_level: debug; level value is 10 - Informationen, die zum Debuggen von Salt-Implementierungen und Salt-Code nützlich sind.

  • log_level: trace; level value is 5 - Detailliertere Informationen zum Code-Debugging.

LOG_LEVEL_LOGFILE

Es definiert die Ebene der Nachrichten, die an die Protokolldatei gesendet werden sollen.

log_level_logfile: info

LOG_DATEFMT

Es definiert das Protokolldatumformat. Standardmäßig wird es als% Y-% m-% d% H:% M:% S dargestellt.

log_datefmt_logfile: '%Y-%m-%d %H:%M:%S'

LOG_FMT_CONSOLE

Es definiert das Format der Konsole, die die Nachrichten protokolliert. Salz verwendet einen BrauchLogRecordAttribute zum Färben der Konsolenprotokollausgabe. Es folgt der folgenden Syntax:

'%(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

Es definiert das Format der Protokolldatei, in der die Nachrichten protokolliert werden. Die grundlegende Syntax lautet wie folgt:

%(asctime)s,%(msecs)03d [%(name)-17s][%(levelname)-8s] %(message)s

LOG_GRANULAR_LEVELS

Diese Ebene wird verwendet, um die Protokollierungsstufen genauer zu steuern.

log_granular_levels:
   'salt': 'info'
   'salt.modules': ‘trace'

Hier setzt die Hauptsalzbibliothek auf der Info-Ebene die salt.modules auf Trace-Ebene zu protokollieren.

Externer Protokollierungshandler

Salt verwendet für die Protokollierung den externen LogStash- und Sentry-Protokollhandler. Lassen Sie uns dies in diesem Kapitel im Detail verstehen.

LOGSTASH-Handler

LogStash ist Open Source. serverseitige sichere Datenverarbeitungspipeline. Betrachten wir einen einfachen UDP-Protokollierungshandler in Salt, der LogStash verwendet.

Geben Sie die folgenden Änderungen in der Salt-Masterdatei an:

logstash_udp_handler:
   host: 127.0.0.1
   port: 9999
   version: 1
   msg_type: logstash

Fügen Sie dann die Änderungen in die Logstash-Konfigurationsdatei ein -

input {
   udp {
      port ⇒ 9999
      codec ⇒ json
   }
}

Hier, UDP - ist die Eingabe, die ein Format als haben muss json_event, was wir über den Draht senden.

SENTRY Logging Handler

Sentry ist eine Echtzeit-Fehlerverfolgung in Produktionsbereitstellungen und Informationen zur Reproduktion und Behebung von Abstürzen. Die Standardkonfiguration in der Masterdatei ist unten definiert.

sentry_handler:
   dsn: https://pub-key:[email protected]/app-id
   log_level: debug

Hier ist die Standardprotokollierungsstufe für den Sentry-Handler ERROR, aber wir haben das Debug definiert log_level unter dem Konfigurationsschlüssel sentry_handler.