Ubuntu 24.04
Sponsored Link

Elastic Stack 8 : Metricbeat インストール2024/08/02

 

CPU やメモリー使用量等のシステム情報のデータ収集機能を提供する Metricbeat をインストールします。

システム情報以外にも、設定により Apache や MySQL のメトリックも収集可能です。詳細は公式サイトを参照ください。
⇒ https://www.elastic.co/guide/en/beats/metricbeat/current/metricbeat-modules.html

[1] Metricbeat をインストールします。 事前に Elasticsearch リポジトリ設定済みであることが前提です。
root@dlp:~#
apt -y install metricbeat
[2] 基本的な設定をして Metricbeat を起動します。
root@dlp:~#
vi /etc/metricbeat/metricbeat.yml
# 67行目 : Kibana を使用する場合はコメント解除して出力先を指定
# Kibana で SSL 有効の場合は証明書に登録したホスト名と合わせる
# [username], [password] は管理ユーザーのユーザー名とパスワード
# 自己署名の証明書を使用している場合は [ssl.verification_mode: none]

setup.kibana:
.....
  host: "https://dlp.srv.world:5601"
  protocol: "https"
  username: "elastic"
  password: "password"
  ssl.enabled: true
  ssl.verification_mode: none

# 99行目 : Elasticsearch の出力先を指定する
# [username], [password] は管理ユーザーのユーザー名とパスワード
# [ssl.certificate_authorities] は Elasticsearch で生成された cacert

output.elasticsearch:
  # Array of hosts to connect to.
  hosts: ["https://dlp.srv.world:9200"]

  protocol: "https"
  username: "elastic"
  password: "password"
  ssl.certificate_authorities: "/etc/elasticsearch/certs/http_ca.crt"

.....
.....

root@dlp:~#
vi /etc/metricbeat/metricbeat.reference.yml
# 61行目 : 収集する項目を設定
# コメントアウト/コメント解除で有効/無効にする

- module: system
  metricsets:
    - cpu             # CPU usage
    - load            # CPU load averages
    - memory          # Memory usage
    - network         # Network IO
    - process         # Per process metrics
    - process_summary # Process summary
    - uptime          # System Uptime
    - socket_summary  # Socket summary
    #- core           # Per CPU core usage
    #- diskio         # Disk IO
    #- filesystem     # File system usage for each mountpoint
    #- fsstat         # File system summary metrics
    #- raid           # Raid
    #- socket         # Sockets and connection info (linux only)
    #- service        # systemd service information
  enabled: true
  period: 10s
  processes: ['.*']

# 2831行目 : Kibana を使用する場合はコメント解除して出力先を指定
# Kibana で SSL 有効の場合は ssl 系設定をコメント解除
# [username], [password] は管理ユーザーのユーザー名とパスワード
# 自己署名の証明書を使用している場合は [ssl.verification_mode: none]

setup.kibana:

  # Kibana Host
  # Scheme and port can be left out and will be set to the default (http and 5601)
  # In case you specify and additional path, the scheme is required: http://localhost:5601/path
  # IPv6 addresses should always be defined as: https://[2001:db8::1]:5601
  host: "https://dlp.srv.world:5601"

   # Optional protocol and basic auth credentials.
  protocol: "https"
  username: "elastic"
  password: "password"

  # Optional HTTP path
  #path: ""

  # Optional Kibana space ID.
  #space.id: ""

  # Use SSL settings for HTTPS.
  ssl.enabled: true
  
.....
.....

  # after very careful consideration. It is primarily intended as a temporary
  # diagnostic mechanism when attempting to resolve TLS errors; its use in
  # production environments is strongly discouraged.
  # The default value is full.
  ssl.verification_mode: none

root@dlp:~#
systemctl enable --now metricbeat
[3] データが取り込まれているか確認しておきます。
# index 一覧

root@dlp:~#
curl -u elastic --cacert /etc/elasticsearch/certs/http_ca.crt https://127.0.0.1:9200/_cat/indices?v

Enter host password for user 'elastic'
health status index                                                              uuid                   pri rep docs.count docs.deleted store.size pri.store.size dataset.size
green  open   .internal.alerts-transform.health.alerts-default-000001            3MDAnVqWRkC_ucXp_f-dRg   1   0          0            0       249b           249b         249b
green  open   .internal.alerts-observability.logs.alerts-default-000001          virq6rX_TAadxqKMrIr4tQ   1   0          0            0       249b           249b         249b
green  open   .internal.alerts-observability.uptime.alerts-default-000001        46XZFk5FRl28WLwbzBCRCw   1   0          0            0       249b           249b         249b
green  open   .internal.alerts-ml.anomaly-detection.alerts-default-000001        03VHbmGgSIOuhotRgmO1Yw   1   0          0            0       249b           249b         249b
green  open   .internal.alerts-observability.slo.alerts-default-000001           IaTLW9hYRIm8y1ikEzlN2g   1   0          0            0       249b           249b         249b
green  open   .internal.alerts-default.alerts-default-000001                     XpCXm0SYQa2o_uT14iMPyw   1   0          0            0       249b           249b         249b
green  open   .internal.alerts-observability.apm.alerts-default-000001           0OrsLwbDRVWozBNNt1RAOA   1   0          0            0       249b           249b         249b
green  open   .internal.alerts-observability.metrics.alerts-default-000001       yQqehuwnTN-ndP0O-YoqYg   1   0          0            0       249b           249b         249b
green  open   .kibana-observability-ai-assistant-conversations-000001            ctEkgFQkTc-2Fec_91qYJA   1   0          0            0       249b           249b         249b
green  open   .internal.alerts-ml.anomaly-detection-health.alerts-default-000001 34FcMwC0S26Gw6PQlsAgHA   1   0          0            0       249b           249b         249b
green  open   .internal.alerts-observability.threshold.alerts-default-000001     b9DylGvaSp6Glf8y8lKITA   1   0          0            0       249b           249b         249b
green  open   .kibana-observability-ai-assistant-kb-000001                       bde5sw2OTaO0TX18GPGY8Q   1   0          0            0       249b           249b         249b
green  open   .internal.alerts-security.alerts-default-000001                    09-NNzj9SBK7QC9yzpFreQ   1   0          0            0       249b           249b         249b
yellow open   test_index                                                         KB7PcAnESd6F8Gz4BJz7AA   1   1          1            0      6.5kb          6.5kb        6.5kb
yellow open   .ds-metricbeat-8.14.3-2024.08.02-000001                            3QM_SeQkRZG-Um9Dopq9Iw   1   1         83            0    458.8kb        458.8kb      458.8kb
green  open   .internal.alerts-stack.alerts-default-000001                       yh_lotA4Q0KsZAx4iIGNig   1   0          0            0       249b           249b         249b

# index のドキュメント一覧

root@dlp:~#
curl -u elastic --cacert /etc/elasticsearch/certs/http_ca.crt https://127.0.0.1:9200/.ds-metricbeat-8.14.3-2024.08.02-000001/_search?pretty

Enter host password for user 'elastic'
{
  "took" : 2,
  "timed_out" : false,
  "_shards" : {
    "total" : 1,
    "successful" : 1,
    "skipped" : 0,
    "failed" : 0
  },
  "hits" : {
    "total" : {
      "value" : 292,
      "relation" : "eq"
    },
    "max_score" : 1.0,
    "hits" : [
      {
        "_index" : ".ds-metricbeat-8.14.3-2024.08.02-000001",
        "_id" : "arCxEJEBh42v6JiLyeYb",
        "_score" : 1.0,
        "_source" : {
          "@timestamp" : "2024-08-02T01:26:02.459Z",
          "agent" : {
            "name" : "dlp.srv.world",
            "type" : "metricbeat",
            "version" : "8.14.3",
            "ephemeral_id" : "a3ab7284-f542-40df-bef7-6019fdafc888",
            "id" : "7654b86e-2a63-4239-8278-1a100d051793"
          },
          "ecs" : {
            "version" : "8.0.0"
          },
          "event" : {
            "duration" : 31693106,
            "dataset" : "system.process",
            "module" : "system"
          },
          "metricset" : {
            "name" : "process",
            "period" : 10000
          },
          "system" : {
            "process" : {
              "num_threads" : 135,
.....
.....
[4] Kibana を稼働させている場合は、サンプルダッシュボードへのデータインポートが可能です。
root@dlp:~#
metricbeat setup --dashboards

Loading dashboards (Kibana must be running and reachable)
Loaded dashboards

関連コンテンツ