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.