Richten Sie einfach eine imfile-Regel in Ihrer /etc/rsyslog.conf ein
#/etc/rsyslog.conf
$ModLoad imfile
$InputFileName /data/mysql/error.log
$InputFileTag mysql-error
$InputFileStateFile stat-mysql-error
$InputFileSeverity error
$InputFileFacility local3
$InputRunFileMonitor
local3.* @@hostname:<portnumber>
Dadurch wird eine Datei überwacht und in der local3-Einrichtung in Syslog gespeichert. Anschließend können Sie alle Daten von der local3-Einrichtung an Ihren Remote-Server senden. Möglicherweise möchten Sie auch Folgendes zu Ihrer rsyslog conf hinzufügen (normalerweise /etc/rsyslog.d/50-default.conf unter Ubuntu), um die local3-Funktion nicht in / var / log / syslog zu speichern:
#/etc/rsyslog.d/50-default.conf
*.*;auth,authpriv.none,local1.none,local2.none,local3.none,local4.none,local5.none,local6.none -/var/log/syslog
Darüber hinaus empfehle ich das Lesen der folgenden rsyslog-Dokumente für eine erweiterte Filterung:
- Der Property Replacer
- Filterbedingungen
Unter Ubuntu musste ich auch die Drop-Privilegien-Zeilen auskommentieren, damit rsyslog die Protokolldatei tatsächlich außerhalb von / var / logs liest.
quelle