業務用エアコン関連の技術情報、エラーコード、環境問題対策に関する別サイト「エアコンの安全な修理・適切なフロン回収」

AlmaLinux10.2 : Suricata + Elastic Stackでログの可視化とモニタリング

前提条件

1.Suricata
SURICATA IDS/IPSはネットワーク上の通信を監視し、不審なトラフィックを検知するオープンソースのIDSです。基本的な仕組みはシグネチャ型であるため、あらかじめ設定した不正な通信を検知できます。また、Suricataは検知だけでなく防御も行えることが特徴です。

2.Elastic Stack,Kibana,Filebeat
Elastic Stackをインストール&設定して、Kibana,Filebeatを使用してSURICATAのログを可視化&検索できるようにする

今回はSuricata IDS と ElasticStack を 次のサーバーにインストールします
・1台目サーバー Suricata IDS & Filebeat : AlmaLinux10.2 IPアドレス(192.168.11.83)
・2台目サーバー Elasticsearch & kibana  : AlmaLinux10.1 IPアドレス(192.168.11.85)

 1台目サーバー : Suricata インストール

1.Suricata のインストールと設定

①Suricata のインストール

# dnf install https://dl.fedoraproject.org/pub/epel/epel-release-latest-10.noarch.rpm
# dnf install yum-plugin-copr
# dnf copr enable @oisf/suricata-8.0

# dnf -y install suricata

バージョンチェック
# suricata -V
This is Suricata version 8.0.4 RELEASE

②Suricataがネットワークパケットを検査するインターフェースとIPアドレスを決定

# ip --brief add
lo               UNKNOWN        127.0.0.1/8 ::1/128 
ens160           UP             192.168.11.83/24 fe80::20c:29ff:fe38:c59d/64

③設定ファイルを編集

# vi /etc/suricata/suricata.yaml

18行目 : コメントアウトしてその下に追加(varsセクションで、ネットワークを定義する)
#HOME_NET: "[192.168.0.0/16,10.0.0.0/8,172.16.0.0/12]"
HOME_NET: "[192.168.11.0/24]"

158行目あたり : 変更
community-id: false → community-id: true

661行目あたり : af-packetセクションのインターフェース名を設定
af-packet:
    - interface: ens160
# vi /etc/sysconfig/suricata

# 8行目 :インターフェイスを変更
# Add options to be passed to the daemon
OPTIONS="-i ens160 --user suricata "

④Suricataのルール更新

# suricata-update

⑤Suricataの起動

# systemctl enable --now suricata
Created symlink '/etc/systemd/system/multi-user.target.wants/suricata.service' → '/usr/lib/systemd/system/suricata.service'.

⑥Suricataの起動確認

# systemctl status suricata

● suricata.service - Suricata Intrusion Detection Service
     Loaded: loaded (/usr/lib/systemd/system/suricata.service; enabled; preset: disabled)
     Active: active (running) since Fri 2026-06-12 15:37:53 JST; 10s ago
 Invocation: 99b45a0bcf3d4c1e94474880bd1add2b
       Docs: man:suricata(1)
    Process: 39610 ExecStartPre=/bin/rm -f /var/run/suricata.pid (code=exited, status=0/SUCCESS)
   Main PID: 39611 (Suricata-Main)
      Tasks: 1 (limit: 22795)
     Memory: 235.3M (peak: 235.3M)
        CPU: 9.930s
     CGroup: /system.slice/suricata.service
             └─39611 /sbin/suricata -c /etc/suricata/suricata.yaml --pidfile /var/run/suricata.pid -i ens160 --user suricata

Jun 12 15:37:53 Lepard systemd[1]: Starting suricata.service - Suricata Intrusion Detection Service...
Jun 12 15:37:53 Lepard systemd[1]: Started suricata.service - Suricata Intrusion Detection Service.
Jun 12 15:37:53 Lepard suricata[39611]: i: suricata: This is Suricata version 8.0.4 RELEASE running in SYSTEM mode

ログを確認

# tail /var/log/suricata/suricata.log

[39611 - Suricata-Main] 2026-06-12 15:37:54 Info: logopenfile: fast output device (regular) initialized: fast.log
[39611 - Suricata-Main] 2026-06-12 15:37:54 Info: logopenfile: eve-log output device (regular) initialized: eve.json
[39611 - Suricata-Main] 2026-06-12 15:37:54 Info: logopenfile: stats output device (regular) initialized: stats.log
[39611 - Suricata-Main] 2026-06-12 15:38:10 Info: detect: 1 rule files processed. 50734 rules successfully loaded, 0 rules failed, 0 rules skipped
[39611 - Suricata-Main] 2026-06-12 15:38:10 Info: threshold-config: Threshold config parsed: 0 rule(s) found
[39611 - Suricata-Main] 2026-06-12 15:38:10 Info: detect: 50739 signatures processed. 1290 are IP-only rules, 4503 are inspecting packet payload, 44710 inspect application layer, 110 are decoder event only
[39611 - Suricata-Main] 2026-06-12 15:38:11 Info: unix-manager: unix socket '/var/run/suricata/suricata-command.socket'
[39611 - Suricata-Main] 2026-06-12 15:38:11 Info: runmodes: ens160: creating 2 threads
[39620 - W#01-ens160] 2026-06-12 15:38:11 Info: ioctl: ens160: MTU 1500
[39611 - Suricata-Main] 2026-06-12 15:38:11 Notice: threads: Threads created -> W: 2 FM: 1 FR: 1   Engine started.

統計情報を確認するには、stats.log ファイルを確認します(デフォルトで8秒ごとに更新)

# tail -f /var/log/suricata/stats.log

より高度な出力であるEVE JSONは、以下のコマンドで生成することができる

# tail -f /var/log/suricata/eve.json

2.Suricata のテスト

①curl ユーティリティで ping テストを実行

# curl http://testmynids.org/uid/index.html
uid=0(root) gid=0(root) groups=0(root)

②指定されたルール番号を使用してログファイルを確認する
Suricataには、デフォルトで有効になっている次の2つのログファイルが付属しています。

/var/log/suricata/fast.log
/var/log/suricata/eve.log
curlリクエストに対応するログエントリーを確認するために、/var/log/suricata/fast.log ログファイルをgrepコマンドを使用してチェックします。2100498 ルール識別子を使用してログエントリーを検索します。(IPv4の場合)

# grep 2100498 /var/log/suricata/fast.log

06/12/2026-15:39:27.117636  [**] [1:2100498:7] GPL ATTACK_RESPONSE id check returned root [**] [Classification: Potentially Bad Traffic] [Priority: 2] {TCP} 13.227.50.36:80 -> 192.168.11.83:33200

 ③/var/log/suricata/eve.log のイベント確認

jq をインストール

# dnf -y install jq

2100498シグネチャを検索して、EVEログのイベントをフィルタリング
2100498の値と一致するsignature_idキーを持つalertオブジェクトを表示

# jq 'select(.alert .signature_id==2100498)' /var/log/suricata/eve.json

{
  "timestamp": "2026-06-12T15:39:27.117636+0900",
  "flow_id": 2058796919635880,
  "in_iface": "ens160",
  "event_type": "alert",
  "src_ip": "13.227.50.36",
  "src_port": 80,
  "dest_ip": "192.168.11.83",
  "dest_port": 33200,
  "proto": "TCP",
  "ip_v": 4,
  "pkt_src": "wire/pcap",
  "community_id": "1:3AU1a1JkWOCMIvR4s5fDbiv+4eE=",
  "alert": {
    "action": "allowed",
    "gid": 1,
    "signature_id": 2100498,
    "rev": 7,
    "signature": "GPL ATTACK_RESPONSE id check returned root",
    "category": "Potentially Bad Traffic",
    "severity": 2,
    "metadata": {
      "confidence": [
        "Medium"
      ],
      "created_at": [
        "2010_09_23"
      ],
      "signature_severity": [
        "Informational"
      ],
      "updated_at": [
        "2019_07_26"
      ]
    }
  },
  "app_proto": "http",
  "direction": "to_client",
  "flow": {
    "pkts_toserver": 6,
    "pkts_toclient": 5,
    "bytes_toserver": 496,
    "bytes_toclient": 876,
    "start": "2026-06-12T15:39:27.086135+0900",
    "src_ip": "192.168.11.83",
    "dest_ip": "13.227.50.36",
    "src_port": 33200,
    "dest_port": 80
  }
}

3.Suricata Rulesの設定

①Suricataにパッケージされているルールセットの表示

# ls -al /var/lib/suricata/rules/
total 43052
drwxr-s--- 2 root     suricata       57 Jun 12 15:37 .
drwxrws--- 5 suricata suricata       46 Jun 12 15:37 ..
-rw-r--r-- 1 root     suricata     3228 Jun 12 15:37 classification.config
-rw-r--r-- 1 root     suricata 44077892 Jun 12 15:37 suricata.rules

②ルールセットを提供するソースのインデックス一覧

# suricata-update list-sources

Name: abuse.ch/feodotracker
  Vendor: Abuse.ch
  Summary: Abuse.ch Feodo Tracker Botnet C2 IP ruleset
  License: CC0-1.0
Name: abuse.ch/sslbl-blacklist
  Vendor: Abuse.ch
  Summary: Abuse.ch SSL Blacklist
  License: CC0-1.0
  Replaces: sslbl/ssl-fp-blacklist
Name: abuse.ch/sslbl-c2
  Vendor: Abuse.ch
  Summary: Abuse.ch Suricata Botnet C2 IP Ruleset
  License: CC0-1.0
Name: abuse.ch/sslbl-ja3
  Vendor: Abuse.ch
  Summary: Abuse.ch Suricata JA3 Fingerprint Ruleset
  License: CC0-1.0
  Replaces: sslbl/ja3-fingerprints
Name: abuse.ch/urlhaus
  Vendor: abuse.ch
  Summary: Abuse.ch URLhaus Suricata Rules
  License: CC0-1.0
Name: aleksibovellan/nmap
  Vendor: aleksibovellan
  Summary: Suricata IDS/IPS Detection Rules Against NMAP Scans
  License: MIT
Name: et/open
  Vendor: Proofpoint
  Summary: Emerging Threats Open Ruleset
  License: MIT
Name: et/pro
  Vendor: Proofpoint
  Summary: Emerging Threats Pro Ruleset
  License: Commercial
  Replaces: et/open
  Parameters: secret-code
  Subscription: https://www.proofpoint.com/us/threat-insight/et-pro-ruleset
Name: etnetera/aggressive
  Vendor: Etnetera a.s.
  Summary: Etnetera aggressive IP blacklist
  License: MIT
Name: oisf/trafficid
  Vendor: OISF
  Summary: Suricata Traffic ID ruleset
  License: MIT
Name: pawpatrules
  Vendor: pawpatrules
  Summary: PAW Patrules is a collection of rules for IDPS / NSM Suricata engine
  License: CC-BY-SA-4.0
Name: ptrules/open
  Vendor: Positive Technologies
  Summary: Positive Technologies Open Ruleset
  License: Custom
Name: scwx/enhanced
  Vendor: Secureworks
  Summary: Secureworks suricata-enhanced ruleset
  License: Commercial
  Parameters: secret-code
  Subscription: https://www.secureworks.com/contact/ (Please reference CTU Countermeasures)
Name: scwx/malware
  Vendor: Secureworks
  Summary: Secureworks suricata-malware ruleset
  License: Commercial
  Parameters: secret-code
  Subscription: https://www.secureworks.com/contact/ (Please reference CTU Countermeasures)
Name: scwx/security
  Vendor: Secureworks
  Summary: Secureworks suricata-security ruleset
  License: Commercial
  Parameters: secret-code
  Subscription: https://www.secureworks.com/contact/ (Please reference CTU Countermeasures)
Name: stamus/lateral
  Vendor: Stamus Networks
  Summary: Lateral movement rules
  License: GPL-3.0-only
Name: stamus/nrd-14-open
  Vendor: Stamus Networks
  Summary: Newly Registered Domains Open only - 14 day list, complete
  License: Commercial
  Parameters: secret-code
  Subscription: https://www.stamus-networks.com/stamus-labs/subscribe-to-threat-intel-feed
Name: stamus/nrd-30-open
  Vendor: Stamus Networks
  Summary: Newly Registered Domains Open only - 30 day list, complete
  License: Commercial
  Parameters: secret-code
  Subscription: https://www.stamus-networks.com/stamus-labs/subscribe-to-threat-intel-feed
Name: stamus/nrd-entropy-14-open
  Vendor: Stamus Networks
  Summary: Newly Registered Domains Open only - 14 day list, high entropy
  License: Commercial
  Parameters: secret-code
  Subscription: https://www.stamus-networks.com/stamus-labs/subscribe-to-threat-intel-feed
Name: stamus/nrd-entropy-30-open
  Vendor: Stamus Networks
  Summary: Newly Registered Domains Open only - 30 day list, high entropy
  License: Commercial
  Parameters: secret-code
  Subscription: https://www.stamus-networks.com/stamus-labs/subscribe-to-threat-intel-feed
Name: stamus/nrd-phishing-14-open
  Vendor: Stamus Networks
  Summary: Newly Registered Domains Open only - 14 day list, phishing
  License: Commercial
  Parameters: secret-code
  Subscription: https://www.stamus-networks.com/stamus-labs/subscribe-to-threat-intel-feed
Name: stamus/nrd-phishing-30-open
  Vendor: Stamus Networks
  Summary: Newly Registered Domains Open only - 30 day list, phishing
  License: Commercial
  Parameters: secret-code
  Subscription: https://www.stamus-networks.com/stamus-labs/subscribe-to-threat-intel-feed
Name: tgreen/hunting
  Vendor: tgreen
  Summary: Threat hunting rules
  License: GPLv3

③ソースを有効にする(tgreen/huntingを有効にする場合)

# suricata-update enable-source tgreen/hunting

12/6/2026 -- 15:41:33 - <Info> -- Using data-directory /var/lib/suricata.
12/6/2026 -- 15:41:33 - <Info> -- Using Suricata configuration /etc/suricata/suricata.yaml
12/6/2026 -- 15:41:33 - <Info> -- Using /usr/share/suricata/rules for Suricata provided rules.
12/6/2026 -- 15:41:33 - <Info> -- Found Suricata version 8.0.4 at /usr/sbin/suricata.
12/6/2026 -- 15:41:33 - <Warning> -- Source index does not exist, will use bundled one.
12/6/2026 -- 15:41:33 - <Warning> -- Please run suricata-update update-sources.
12/6/2026 -- 15:41:33 - <Info> -- Creating directory /var/lib/suricata/update/sources
12/6/2026 -- 15:41:33 - <Info> -- Enabling default source et/open
12/6/2026 -- 15:41:33 - <Info> -- Source tgreen/hunting enabled

アップデートを実行

# suricata-update  update-sources

Suricata service再起動

# systemctl restart suricata

4. SuricataをIPSに設定する

悪意のあるネットワーク・トラフィックをドロップするようにSuricataをIPSモードで起動するように設定する

非SSHポートへのSSHトラフィックをスキャンする以下のカスタム署名を作成し、/var/lib/suricata/rules/local.rulesというファイルにインクルードする(SSHポートは22と仮定する)

# vi /var/lib/suricata/rules/local.rules

alert ssh any any -> 192.168.11.83 !22 (msg:"SSH TRAFFIC on non-SSH port"; flow:to_client, not_established; classtype: misc-attack; target: dest_ip; sid:1000000;)

/etc/suricata/suricata.yaml設定ファイルを編集し、local.rulesをインクルードする

# vi /etc/suricata/suricata.yaml

2320行目あたりに追加
rule-files:
  - suricata.rules
  - local.rules

SURICATAの設定を検証

# suricata -T -c /etc/suricata/suricata.yaml -v

--------------------------------------------------
Info: detect: 50740 signatures processed. 1290 are IP-only rules, 4503 are inspecting packet payload, 44711 inspect application layer, 110 are decoder event only
Notice: suricata: Configuration provided was successfully loaded. Exiting.

SURICATAの/etc/sysconfig/suricata設定ファイルを編集する

# vi /etc/sysconfig/suricata

8行目 : コメントにして、その下に追加(SURICATAにIPSモードで実行するように指示する)
# OPTIONS="-i ens160 --user suricata"
OPTIONS="-q 0 -vvv --user suricata"

Suricataを再起動

# systemctl restart suricata.service

ステータス確認

# systemctl status suricata.service

● suricata.service - Suricata Intrusion Detection Service
     Loaded: loaded (/usr/lib/systemd/system/suricata.service; enabled; preset: disabled)
     Active: active (running) since Fri 2026-06-12 15:45:52 JST; 25s ago
 Invocation: d015754e35b441a7ad3524164b43e97b
       Docs: man:suricata(1)
    Process: 39916 ExecStartPre=/bin/rm -f /var/run/suricata.pid (code=exited, status=0/SUCCESS)
   Main PID: 39918 (Suricata-Main)
      Tasks: 10 (limit: 22795)
     Memory: 412.3M (peak: 412.6M)
        CPU: 17.233s
     CGroup: /system.slice/suricata.service
             └─39918 /sbin/suricata -c /etc/suricata/suricata.yaml --pidfile /var/run/suricata.pid -q 0 -vvv --user suricata

Jun 12 15:46:09 Lepard suricata[39918]: [39918] Perf: mpm-hs-cache: rule group caching - loaded: 115 newly cached: 0 total cacheable: 115 
Jun 12 15:46:09 Lepard suricata[39918]: [39918] Info: unix-manager: unix socket '/var/run/suricata/suricata-command.socket'
Jun 12 15:46:09 Lepard suricata[39918]: [39918] Config: tmqh-flow: AutoFP mode using "Hash" flow load balancer
Jun 12 15:46:09 Lepard suricata[39918]: [39933] Info: nfq: binding this thread 0 to queue '0'
Jun 12 15:46:09 Lepard suricata[39918]: [39933] Info: nfq: setting queue length to 4096
Jun 12 15:46:09 Lepard suricata[39918]: [39933] Info: nfq: setting nfnl bufsize to 6144000
Jun 12 15:46:09 Lepard suricata[39918]: [39918] Config: flow-manager: using 1 flow manager threads
Jun 12 15:46:09 Lepard suricata[39918]: [39918] Config: flow-manager: using 1 flow recycler threads
Jun 12 15:46:09 Lepard suricata[39918]: [39918] Config: log-flush: log flusher thread not used with heartbeat.output-flush-interval of 0  
Jun 12 15:46:09 Lepard suricata[39918]: [39918] Notice: threads: Threads created -> RX: 1 W: 2 TX: 1 FM: 1 FR: 1   Engine started.  

入ってくるネットワーク・トラフィックをSuricataのNFQUEUEに向ける
Firewalld がインストールされ、有効になっているのでSuricataに必要なルールをFirewalldに追加する(SSHポートは22と仮定する)

# firewall-cmd --permanent --direct --add-rule ipv4 filter INPUT 0 -p tcp --dport 22 -j NFQUEUE --queue-bypass
# firewall-cmd --permanent --direct --add-rule ipv4 filter OUTPUT 0 -p tcp --sport 22 -j NFQUEUE --queue-bypass

IPv6用の同じルールを追加する:
# firewall-cmd --permanent --direct --add-rule ipv6 filter INPUT 0 -p tcp --dport 22 -j NFQUEUE --queue-bypass
# firewall-cmd --permanent --direct --add-rule ipv6 filter OUTPUT 0 -p tcp --sport 22 -j NFQUEUE --queue-bypas

FORWARDルールを追加して、サーバーが他のシステムのゲートウェイとして動作している場合、そのトラフィックもすべてSURICATAに行って処理されるようにします。
# firewall-cmd --permanent --direct --add-rule ipv4 filter FORWARD 0 -j NFQUEUE
# firewall-cmd --permanent --direct --add-rule ipv6 filter FORWARD 0 -j NFQUEUE

最後の2つのINPUTとOUTPUTルールは、SSHトラフィックでない残りのトラフィックをすべてSuricataに送って処理させる。
# firewall-cmd --permanent --direct --add-rule ipv4 filter INPUT 1 -j NFQUEUE
# firewall-cmd --permanent --direct --add-rule ipv4 filter OUTPUT 1 -j NFQUEUE

IPv6も同様にする
# firewall-cmd --permanent --direct --add-rule ipv6 filter INPUT 1 -j NFQUEUE
# firewall-cmd --permanent --direct --add-rule ipv6 filter OUTPUT 1 -j NFQUEUE

Firewalldをリロード
# firewall-cmd --reload

SURICATA がトラフィックを正しくドロップしていることを確認
シグネチャのデフォルトアクションをalertやlogからactive dropping trafficに切り替える
/var/lib/suricata/rules/suricata.rulesファイルを開き、sid:2100498に該当するものがあれば コメントアウトする

# vi /var/lib/suricata/rules/suricata.rules

#alert ip any any -> any any (msg:"GPL ATTACK_RESPONSE id check returned root"; content:"uid=0|28|root|29|"; classtype:bad-unknown; sid:2100498; rev:7; metadata:created_at 2010_09_23, confidence Medium, signature_severity Informational, updated_at 2019_07_26;) 

/var/lib/suricata/rules/local.rulesにsid:2100498として新規作成する

# vi /var/lib/suricata/rules/local.rules

drop ip any any -> any any (msg:"GPL ATTACK_RESPONSE id check returned root"; content:"uid=0|28|root|29|"; classtype:bad-unknown; sid:2100498; rev:7; metadata:created_at 2010_09_23, confidence Medium, signature_severity Informational, updated_at 2019_07_26;)

Suricata再起動

# systemctl restart suricata

curlを使ってこのルールをテスト

# curl --max-time 5 http://testmynids.org/uid/index.html
curl: (28) Operation timed out after 5000 milliseconds with 0 out of 39 bytes received

jqを使ってeve.logファイルを調べる

# jq 'select(.alert .signature_id==2100498)' /var/log/suricata/eve.json

{
  "timestamp": "2026-06-12T15:53:56.077055+0900",
  "flow_id": 1376812478641271,
  "event_type": "alert",
  "src_ip": "13.227.50.46",
  "src_port": 80,
  "dest_ip": "192.168.11.83",
  "dest_port": 49316,
  "proto": "TCP",
  "ip_v": 4,
  "pkt_src": "wire/pcap",
  "community_id": "1:4kGuiwh1h/JJ75NVfZVfm7uXGl4=",
  "alert": {
    "action": "blocked",
    "gid": 1,
    "signature_id": 2100498,
    "rev": 7,
    "signature": "GPL ATTACK_RESPONSE id check returned root",
    "category": "Potentially Bad Traffic",
    "severity": 2,
    "metadata": {
      "confidence": [
        "Medium"
      ],
      "created_at": [
        "2010_09_23"
      ],
      "signature_severity": [
        "Informational"
      ],
      "updated_at": [
        "2019_07_26"
      ]
    }
  },
  "app_proto": "http",
  "direction": "to_client",
  "flow": {
    "pkts_toserver": 3,
    "pkts_toclient": 4,
    "bytes_toserver": 256,
    "bytes_toclient": 754,
    "start": "2026-06-12T15:53:56.058420+0900",
    "src_ip": "192.168.11.83",
    "dest_ip": "13.227.50.46",
    "src_port": 49316,
    "dest_port": 80
  }
}

"action": "blocked",になっている

ELK StackとSURICATAの統合

Elastic Stackをインストール&設定して、SURICATAのログをより効率的に可視化&検索できるようにする
本セクションは基本的には2台目のAlmaLinux10.1サーバーで行います

1. Elasticsearchのインストール

1.1 公開署名キーをダウンロードしてインストール

# rpm --import https://artifacts.elastic.co/GPG-KEY-elasticsearch

1.2 リポジトリ定義を/etc/yum/yum.repos.d ディレクトリに作成

#  vi /etc/yum.repos.d/elasticsearch.repo

下記内容記述
[elasticsearch]
name=Elasticsearch repository for 9.x packages
baseurl=https://artifacts.elastic.co/packages/9.x/yum
gpgcheck=1
gpgkey=https://artifacts.elastic.co/GPG-KEY-elasticsearch
enabled=0
autorefresh=1
type=rpm-md

1.3 Elasticsearch インストール

# dnf -y install --enablerepo=elasticsearch elasticsearch

2. Elasticsearch 設定

Elasticsearchはデフォルトでローカル接続のみを受け付けるように設定されています。また、認証が有効になっていないため、Filebeatなどのツールはログを送信できません。今回は、Elasticsearchのネットワーク設定を行い、Elasticsearchに組み込まれているxpackセキュリティモジュールを有効にします。

2.1 Elasticsearchネットワークの設定
ElasticsearchとSURICATAのサーバは別々なので、Elasticsearchがプライベートネットワークインターフェースで接続をリッスンするように設定する必要がある

# vi /etc/elasticsearch/elasticsearch.yml

57行目 : Elasticsearch serverのローカルアドレス追加
#network.host: 192.168.0.1
network.host: 192.168.11.85 

62行目コメント解除
http.port: 9200

2.2 Elasticsearch を起動

# systemctl daemon-reload
# systemctl enable elasticsearch.service
# systemctl start elasticsearch.service

2.3 elasticとkibana_systemのパスワードを作成
elasticユーザとkibana_systemユーザのパスワードは後で使用するので必ずコピーしておく
kibana_systemユーザはKibanaの設定に使用する
elasticユーザはFilebeat、Auditbeatの設定およびKibanaへのログインに使用する
パスワードを忘れた場合は、再度コマンドを使用してパスワードをリセットできます。

[elastic] userのパスワード作成

# cd /usr/share/elasticsearch/bin

# ./elasticsearch-reset-password -u elastic
This tool will reset the password of the [elastic] user to an autogenerated value.
The password will be printed in the console.
Please confirm that you would like to continue [y/N]y


Password for the [elastic] user successfully reset.
New value: gEhzfFt14nWpz_qhzBVT

※Elasticsearch パスワードのリセット
自動生成されたElasticユーザーパスワードが複雑すぎるので、/usr/share/elasticsearch/bin/elasticsearch-reset-passwordコマンドを使ってリセットできます
パスワードをリセットするには、コマンドを実行する

# /usr/share/elasticsearch/bin/elasticsearch-reset-password -u elastic -i

This tool will reset the password of the [elastic] user.
You will be prompted to enter the password.
Please confirm that you would like to continue [y/N]y


Enter password for [elastic]:
Re-enter password for [elastic]: 
Password for the [elastic] user successfully reset.

[kibana_system]userのパスワード作成

# cd /usr/share/elasticsearch/bin

# ./elasticsearch-reset-password -u kibana_system
This tool will reset the password of the [kibana_system] user to an autogenerated value.
The password will be printed in the console.
Please confirm that you would like to continue [y/N]y


Password for the [kibana_system] user successfully reset.
New value: j9KPyvbbH+ZP+0qkmHzQ

3. Kibana のインストールと設定

本セクションは2台目のAlmaLinux10.1サーバーで行います

3.1 Kibanaインストール

# dnf -y install --enablerepo=elasticsearch kibana

Installed:
  kibana-9.4.2-1.x86_64

Complete!

3.2 xpackセキュリティモジュールの設定

Kibana の xpack セキュリティ機能を有効にして、Kibana が Elasticsearch にデータを保存するために使用するいくつかの暗号化キーを作成する。
暗号化キーは、/usr/share/kibana/bin ディレクトリに含まれる kibana-encryption-keys ユーティリティを使用して作成する。
作成した3つのキーを安全な場所に保存しておく

# cd /usr/share/kibana/bin/
# ./kibana-encryption-keys generate -q --force

xpack.encryptedSavedObjects.encryptionKey: ee0c9866090808a56c34ebafcb0c20ff4c56f8436666b9f4e3aedaa43cc5e79c
xpack.reporting.encryptionKey: 72ecfed59b91a7b68c3651652bc6f862c91c743e8a254656110930ddc2c7bec6
xpack.security.encryptionKey: d90e9970f97ae7dbc92148d14eba10881321cb4842ac52e7ab106f5d3eb5869f

これらのキーをKibanaの/etc/kibana/kibana.yml設定ファイルに追加する

# vi /etc/kibana/kibana.yml

最終行に記述
xpack.encryptedSavedObjects.encryptionKey: ee0c9866090808a56c34ebafcb0c20ff4c56f8436666b9f4e3aedaa43cc5e79c
xpack.reporting.encryptionKey: 72ecfed59b91a7b68c3651652bc6f862c91c743e8a254656110930ddc2c7bec6
xpack.security.encryptionKey: d90e9970f97ae7dbc92148d14eba10881321cb4842ac52e7ab106f5d3eb5869f

3.3 Kibana ネットワークの設定

# vi /etc/kibana/kibana.yml

6行目 : コメント解除
server.port: 5601

12行目 : サーバーのプライベートIPアドレス(192.168.11.85)を追加
#server.host: "localhost"
server.host: "192.168.11.85"

3.4 Kibana-Elasticsearch Enrollment Token の生成
Kibana インスタンスを、セキュリティ機能が有効になっている既存の Elasticsearch クラスタと通信するように設定するには、登録トークンが必要です。Kibana 用の Enrollment Token は以下のコマンドで生成できる

# /usr/share/elasticsearch/bin/elasticsearch-create-enrollment-token -s kibana
eyJ2ZXIiOiI4LjE0LjAiLCJhZHIiOlsiMTkyLjE2OC4xMS44NTo5MjAwIl0sImZnciI6ImNlMDA2ZWYxZjVkMGFiNDQwNjcxMmU0OWZmZjJmNGI5M2FkMmIyNTc4NGNjZjc0YjNmYTBiM2QyNGFhYmZiZjQiLCJrZXkiOiJRaWFudXA0Qk53cXdzTTJWbW5LVjp1M3pPdnZyRDZYTi1WNFgyeUVYdnl3In0=

3.5 Kibanaの起動
Kibana 9 を起動し、システム起動時に実行できるようにする。

# systemctl enable --now kibana
# systemctl start kibana

ステータス確認

# systemctl status kibana

● kibana.service - Kibana
     Loaded: loaded (/usr/lib/systemd/system/kibana.service; enabled; preset: disabled)
     Active: active (running) since Fri 2026-06-12 16:07:11 JST; 1min 0s ago
 Invocation: f6ba60f6baee451c8ab423951cfb48d4
       Docs: https://www.elastic.co
   Main PID: 40788 (MainThread)
      Tasks: 11 (limit: 16792)
     Memory: 798.8M (peak: 799.9M)
        CPU: 16.207s
     CGroup: /system.slice/kibana.service
             mq40788 /usr/share/kibana/bin/../node/default/bin/node /usr/share/kibana/bin/../src/cli/kibana/dist

Jun 12 16:07:24 Lion kibana[40788]: Native global console methods have been overridden in production environment.
Jun 12 16:07:32 Lion kibana[40788]: [2026-06-12T16:07:32.393+09:00][INFO ][root] Kibana is starting
Jun 12 16:07:32 Lion kibana[40788]: [2026-06-12T16:07:32.444+09:00][INFO ][node] Kibana process configured with roles: [background_tasks, ui]
Jun 12 16:07:58 Lion kibana[40788]: [2026-06-12T16:07:58.525+09:00][INFO ][plugins-service] The following plugins are disabled: "alertingVTwo,cloudChat,cloudExperiments,cloudFullStory,dataUsage,>
Jun 12 16:07:58 Lion kibana[40788]: [2026-06-12T16:07:58.604+09:00][INFO ][http.server.Preboot] http server running at http://192.168.11.85:5601
Jun 12 16:07:58 Lion kibana[40788]: [2026-06-12T16:07:58.947+09:00][INFO ][plugins-system.preboot] Setting up [1] plugins: [interactiveSetup]
Jun 12 16:07:58 Lion kibana[40788]: [2026-06-12T16:07:58.987+09:00][INFO ][preboot] "interactiveSetup" plugin is holding setup: Validating Elasticsearch connection configuration…
Jun 12 16:07:59 Lion kibana[40788]: [2026-06-12T16:07:59.027+09:00][INFO ][root] Holding setup until preboot stage is completed.
Jun 12 16:08:06 Lion kibana[40788]: i Kibana has not been configured.
Jun 12 16:08:06 Lion kibana[40788]: Go to http://192.168.11.85:5601/?code=266616 to get started.

出力の最後のほうに以下のように表示される

Go to http://192.168.11.85:5601/?code=266616 to get started.

提供されたKibanaのURL(codeを含む)をコピーしてブラウザで使用し、Kibanaにアクセスしてセットアップを完了する。

4. Kibana9 ダッシュボードにアクセスする

Firewallが起動している場合は、Kibanaポートを開く

# firewall-cmd --add-port=5601/tcp --permanent
# firewall-cmd --reload

http://192.168.11.85:5601/?code=266616にアクセスする
(各自の適切なアドレスをコピー)

Kibana 9にアクセスすると、ウェルカムページでElasticの設定を求められます。
最初に、生成した登録トークンを入力する。
/usr/share/elasticsearch/bin/elasticsearch-create-enrollment-token -s kibana, コマンドを使用して生成された Kibana トークンをコピーし、ボックスに貼り付ける

トークンをペーストすると、Kibana が自動的に Elasticsearch に接続します。
Configure Elastic をクリックします。設定が保存され、Elasticsearch が設定、再起動されます。

ログインページに移動します。生成されたElasticユーザー認証情報を使用してログインします。
Username : elastic
Password : わかりやすく再生成したパスワード

ウェルカムページで、「Explore on my own」をクリックしてKibana 9.xダッシュボードに進む。

elasticスーパーユーザーアカウントを使う必要がないように、新しいユーザーアカウントを作成します。
メインメニューを開き、Stack Management >Security> Users

右上の"Create user"ボタンをクリック

新規ユーザー情報を入力し、Privilegesでkibana_admin、kibana_system、monitoring_user、editorのロールを割り当てる
最後に[Create user]をクリックする

現在のプロファイルからログアウトし、新しく作成したユーザーアカウントでログインできることを確認する。現在、SURICATAのホストでFilebeatとAuditbeatを設定していないため、Kibanaで表示できるデータがありません。

SURICATAサーバにFilebeatをインストール

本作業はSuricataをインストールした1台目のAlmaLinux10.2サーバーで作業する

1. Filebeat インストール

1.1 Elasticsearch GPGキーをダウンロード

# rpm --import https://artifacts.elastic.co/GPG-KEY-elasticsearch

1.2 /etc/yum/yum.repos.dディレクトリにelasticsearch.repoファイルを以下の内容で、作成

# vi /etc/yum.repos.d/elasticsearch.repo

以下内容を記述
[elasticsearch]
name=Elasticsearch repository for 9.x packages
baseurl=https://artifacts.elastic.co/packages/9.x/yum
gpgcheck=1
gpgkey=https://artifacts.elastic.co/GPG-KEY-elasticsearch
enabled=0
autorefresh=1
type=rpm-md

1.3 Filebeatをインストール

# dnf -y install --enablerepo=elasticsearch filebeat
Installed:
  filebeat-9.4.2-1.x86_64

1.4 Elasticsearch CA証明書作成
Elasticsearch CA証明書をダウンロードし、任意のディレクトリに保存します(今回は/etc/filebeat/elastic-ca.crtとして保存します)
※第2サーバー(RockyLinux10.1 Elasticsearchを導入したサーバー)で9200ポートを開放しておく

# openssl s_client -connect 192.168.11.85:9200 \
-showcerts </dev/null 2>/dev/null | \
openssl x509 -outform PEM > /etc/filebeat/elastic-ca.crt

1.5 FilebeatをElasticsearchとKibanaに接続するように設定

# vi /etc/filebeat/filebeat.yml

138行目 : KibanaインスタンスのプライベートIPアドレスとポートを指す行を追加する
#host: "localhost:5601"
host: "192.168.11.85:5601"

164行目 : コメントアウト
#hosts: ["localhost:9200"]

165行目 : Elasticsearch のipアドレスとelasticsearchのポート番号を入力
hosts: ["https://192.168.11.85:9200"]

171行目 : コメント解除
protocol: "https"

172行目 : Elasticsearch CA証明書指定
ssl.certificate_authorities: ["/etc/filebeat/elastic-ca.crt"]

175,176行目コメント解除し、[username]はデフォルトのままにし、[password]は[elastic]ユーザーのパスワードを入力する
username: "elastic"
password: “xxxxxxxxx"

1.6 設定ファイルテスト

# filebeat test config
Config OK

1.7 Filebeatsの組み込みSuricataモジュールを有効にする

# filebeat modules enable suricata

上記コマンドにより /etc/filebeat/modules.d/suricata.yml.disabled が/etc/filebeat/modules.d/suricata.yml になりますが内容は変化しませんので以下のように編集します

# vi /etc/filebeat/modules.d/suricata.yml

6-7行目 : 下記のとおり変更
  eve:
    enabled: true
    var.paths: ["/var/log/suricata/eve.json"]

1.8 初期環境をセットアップ
Suricataサービスにpipeline
SIEMダッシュボードをElasticsearchにロードします

# filebeat setup -e

-----------------------------------------------------------------------------------------------------------------------------------------
{"log.level":"info","@timestamp":"2026-06-12T16:30:53.795+0900","log.logger":"modules","log.origin":{"function":"github.com/elastic/beats/v7/filebeat/fileset.LoadPipeline","file.name":"fileset/pipelines.go","file.line":134},"message":"Elasticsearch pipeline loaded.","service.name":"filebeat","pipeline":"filebeat-9.4.2-suricata-eve-pipeline","ecs.version":"1.6.0"}
{"log.level":"info","@timestamp":"2026-06-12T16:30:53.870+0900","log.logger":"modules","log.origin":{"function":"github.com/elastic/beats/v7/filebeat/fileset.LoadPipeline","file.name":"fileset/pipelines.go","file.line":134},"message":"Elasticsearch pipeline loaded.","service.name":"filebeat","pipeline":"filebeat-9.4.2-suricata-eve-dns","ecs.version":"1.6.0"}
{"log.level":"info","@timestamp":"2026-06-12T16:30:53.910+0900","log.logger":"modules","log.origin":{"function":"github.com/elastic/beats/v7/filebeat/fileset.LoadPipeline","file.name":"fileset/pipelines.go","file.line":134},"message":"Elasticsearch pipeline loaded.","service.name":"filebeat","pipeline":"filebeat-9.4.2-suricata-eve-dns-answer-v1","ecs.version":"1.6.0"}
{"log.level":"info","@timestamp":"2026-06-12T16:30:53.950+0900","log.logger":"modules","log.origin":{"function":"github.com/elastic/beats/v7/filebeat/fileset.LoadPipeline","file.name":"fileset/pipelines.go","file.line":134},"message":"Elasticsearch pipeline loaded.","service.name":"filebeat","pipeline":"filebeat-9.4.2-suricata-eve-dns-answer-v2","ecs.version":"1.6.0"}
{"log.level":"info","@timestamp":"2026-06-12T16:30:53.998+0900","log.logger":"modules","log.origin":{"function":"github.com/elastic/beats/v7/filebeat/fileset.LoadPipeline","file.name":"fileset/pipelines.go","file.line":134},"message":"Elasticsearch pipeline loaded.","service.name":"filebeat","pipeline":"filebeat-9.4.2-suricata-eve-tls","ecs.version":"1.6.0"}
{"log.level":"info","@timestamp":"2026-06-12T16:30:54.070+0900","log.logger":"modules","log.origin":{"function":"github.com/elastic/beats/v7/filebeat/fileset.LoadPipeline","file.name":"fileset/pipelines.go","file.line":134},"message":"Elasticsearch pipeline loaded.","service.name":"filebeat","pipeline":"filebeat-9.4.2-suricata-eve-http","ecs.version":"1.6.0"}
-----------------------------------------------------------------------------------------------------------------------------------------

1.9 Filebeatサービスを開始

# systemctl start filebeat.service

2. Kibanaで確認

作成したユーザーでKibanaにログインし直します。http://192.168.11.85:5601にアクセスします。

一番上の検索フィールドに「Suricata Events Overview」と入力し、Events Overviewをクリック

過去 15 分間のすべての Suricata イベントが表示されます

悪質なトラフィックのアラートを表示するにはSuricataロゴの横にあるAlertsテキストをクリック

Kibana には、ログを視覚化するためのさまざまな機能とツールがありますのでいろいろと試してください。