この記事では、WindowsイベントログをEasyBlocks Syslogに転送する方法について紹介していきます!
EasyBlocks Syslogを利用するにあたって…
data:image/s3,"s3://crabby-images/6bab4/6bab4ed2bebea19577de839d0548f41fb135a686" alt=""
Windows ServerのログもSyslog収集したい…
data:image/s3,"s3://crabby-images/cc9b3/cc9b34993577c1810327fe100759747a6022dc31" alt=""
WindowsイベントログをEasyBlocks Syslogで一元管理したい…
という場合があります。
Windows Serverのログは「イベント・ログ形式」になっており、「Syslog形式」のログを収集・保存する EasyBlocks SyslogにはSyslog転送することができません。
しかし、NXLogを利用することにより、このイベントログを EasyBlocks SyslogにSyslog転送できるようになります!
はじめに
今回は Windows Serverとして、OpenBlocks IX9(Windows 10 IoT)を使用します。
この OpenBlocks IX9には、NXLog Community Editionをダウンロード、インストールをします。
NXLog Community Editionとは、ヨーロッパのNXLog社が開発しているオープンソースの Windowsログ収集ツールです。このNXLogは WindowsイベントログをSyslog形式に変換することができるため、Windowsのログを EasyBlocks SyslogにSyslog転送できるようになります。
☟NXLogのダウンロードはコチラのURLから☟
製品環境
EasyBlocks Syslog :ソフトバージョン 1.1.7(初期設定のみ)
OpenBlocks IX9(Windows 10 IoT)
NXLog Community Edition:Windows版
OpenBlocks IX9へ NXLog Community Editionをインストールします。
EasyBlocks Syslogと OpenBlocks IX9は、共通のネットワークに LAN接続しています。
参考サイト
【Windows】イベントログをLinuxに転送する #Linux – Qiita
DigiLoog » NXLogでWindowsイベントログをsyslog転送してみた (ns-lab.org)
Windows/Binary/NXLog – nowsky system-lab memo (ns-lab.org)
Syslog転送する手順
NXLogの設定ファイル編集
インストールが完了した後、設定ファイルを編集します。
C:\Program Files\nxlog\conf\nxlog.conf
ファイル内容を以下のように変更します。
## This is a sample configuration file. See the nxlog reference manual about the ## configuration options. It should be installed locally and is also available ## online at http://nxlog.org/docs/ ## Please set the ROOT to the folder your nxlog was installed into, ## otherwise it will not start. define ROOT C:\Program Files\nxlog #define ROOT C:\Program Files (x86)\nxlog Moduledir %ROOT%\modules CacheDir %ROOT%\data Pidfile %ROOT%\data\nxlog.pid SpoolDir %ROOT%\data LogFile %ROOT%\data\nxlog.log <Extension syslog> Module xm_syslog </Extension> <Extension charconv> Module xm_charconv AutodetectCharsets shift_jis, utf-8 </Extension> <Extension json> Module xm_json </Extension> <Input msv> Module im_msvistalog Query <QueryList>\ <Query Id="0">\ <Select Path="Application">*[System[(Level=1 or Level=2 or Level=3 or Level=4)]]</Select>\ <Select Path="System">*[System[(Level=1 or Level=2 or Level=3 or Level=4)]]</Select>\ <Select Path="Security">*[System[(Level=1 or Level=2 or Level=3 or Level=4)]]</Select>\ </Query>\ </QueryList> Exec $Hostname = hostname(); Exec $raw_event = "json=" + to_json(); $SyslogFacilityValue = 21; Exec convert_fields("utf-8", "utf-8"); </Input> <Processor tra> Module pm_transformer OutputFormat syslog_bsd Exec $Message=(": "+$raw_event); </Processor> <Output udp> Module om_udp Host xxx.xxx.xxx.xxx Port 514 </Output> <Route 1> Path msv => tra => udp </Route>
<Input msv>の <Select Path=”Application”>、<Select Path=”System”>、<Select Path=”Security”>では各イベントログの出力とLevelを指定しています。
Level1=CRITICAL、Level2=ERROR、Level3=WARNING、Level4=INFO
<Output udp>の Hostには、EasyBlocks Syslogの IPアドレスを指定します。
Portには、514を指定します。
以上でNXLogの設定ファイル編集は完了です。
完了後、EasyBlocks Syslogに画像のようなログが転送されてます。
最後に
今回は、WindowsイベントログをEasyBlocks Syslogに転送する方法について紹介しました。EasyBlocks Syslogを利用している方で「Windows Serverの状況も確認したい!」という場合のご参考になれば幸いです。
data:image/s3,"s3://crabby-images/4e74b/4e74b4707a0fe856bcf156001e7156d7ac6d8ac3" alt=""
data:image/s3,"s3://crabby-images/f6228/f622845d86f87b40348a0845908e3830540fb41b" alt=""
また、EasyBlocks Network Reporterにも同様の設定でSyslog転送することができます。
data:image/s3,"s3://crabby-images/ec552/ec5521461e3c3613a0070e729bc9cf11f69d1311" alt=""
2024年4月23日追記:セキュリティログについて
WindowsのセキュリティログをSyslog転送する際に、
“成功の監査“もしくは”AUDIT SUCCESS“というログを記録したい場合は、
設定ファイルの<Select Path=”Security”>の行を以下のように変更することでSyslog転送されます。
<Select Path="Security">*[System[Provi der[@Name='Microsoft-Windows- Security-Auditing']]]</Select> \