はじめに
GraylogではDashboardにて地図にアクセスのあった地域を表示することができます。
このIPアドレスから地域を推定することをGeoIPと呼びますがデフォルトではGeoIP用のデータベースが無いため表示できません。
また設定方法も特別な設定が必要で分かりにくい工程があります。
この方法をメモしておきます。
環境
OS: Rocky Linux 8.6
Graylog: 5.0.11
手順
MaxMindのアカウントを作成
まず、GeoIPのデータベースを取得するため、GeoIPのデータベースを提供しているMaxMind社のアカウントを作成します。
ファイルダウンロード
アカウントを作成後、ログインすると、左側に「Download Files」というメニューがあるので開きます。
data:image/s3,"s3://crabby-images/5fdb4/5fdb4af8e680e15e4e148c5c24a49dc274531fe1" alt=""
ファイル一覧が表示されるので、「GeoLite2 City」をダウンロードします。
data:image/s3,"s3://crabby-images/b1c60/b1c60e5c0ea694e904902e40e8cb0373db90bef0" alt=""
データベースの配置
ファイルを解凍してgraylogの入っているサーバーの「/etc/graylog/server/GeoLite2-City.mmdb」に置きます。
# ls /etc/graylog/server/
GeoLite2-City.mmdb log4j2.xml node-id server.conf
データベースの読み込み
Graylogの画面に移動し、「System > Lookup Tables > Data Adapters」を開きます。
「Create data adapter」をクリックして、DataAdapter Type を 「GeoIP -MaxMind」を選択します。
他はデフォルトで良いです。Titleを設定して「Create Adapter」をクリックして作成します。
data:image/s3,"s3://crabby-images/096ad/096addfde295f2a299a0109e45f369aadc362be0" alt=""
キャッシュの作成
次にキャッシュを作成します。
data:image/s3,"s3://crabby-images/6962d/6962dd6e90772ec791739ef6dbafa4324ec192f7" alt=""
Lookup Tableの作成
data:image/s3,"s3://crabby-images/a1b68/a1b68b181873d054a66cef59db8540479bec8595" alt=""
ルールの作成
これだけではデータベースを読み込めるようにしただけですので、実際のIPアドレスをGeoIPで所在地を取得するルールを作成します。
「System > Pipelines > Manage rules」にて次のコードを貼り付けます。
※ meta_req_headers_x-real-ip は自身のIPアドレスのカラムを指定してください
rule "GeoIP lookup: meta_req_headers_x-real-ip"
when
has_field("meta_req_headers_x-real-ip")
then
let geo = lookup("geoip", to_string($message."meta_req_headers_x-real-ip"));
set_field("src_ip_geo_location", geo["coordinates"]);
set_field("src_ip_geo_country", geo["country"].iso_code);
set_field("src_ip_geo_city", geo["city"].names.en);
end
data:image/s3,"s3://crabby-images/11648/116489cd1c2517ee6347989a17d259a04965ae6f" alt=""
Pipelineの作成
「System > Pipelines > Pipeline」にてPipelineを作成します。
data:image/s3,"s3://crabby-images/acb55/acb554959fc5c787a6087953016b42797e7c1d44" alt=""
続いて、Editを行い、次のように設定します。
Pipeline Connections
data:image/s3,"s3://crabby-images/4b647/4b647628395d7cccf421faf8a130648eaba60a5c" alt=""
Stage 0
data:image/s3,"s3://crabby-images/1f53a/1f53a9b1f1ad5d7910b02eb9ff26fe8604103844" alt=""
data:image/s3,"s3://crabby-images/adca8/adca89b36e92ab540c4d0c4501d5c3a5b91d4ae2" alt=""
動作確認
以上で設定完了です。
成功していればメッセージにGeoIPの項目が増えています。
data:image/s3,"s3://crabby-images/cddd6/cddd62bb51ae29bebba55ccde255c0e453c714fc" alt=""
Dashboardでは次のように設定すると地図に反映されます。
data:image/s3,"s3://crabby-images/67ff0/67ff063d77e07ae1231569979ed80ceccef2ca41" alt=""
参考
data:image/s3,"s3://crabby-images/0240f/0240fb0eee2a088f6a93790ffeb85986e3b0b74d" alt=""
data:image/s3,"s3://crabby-images/19f89/19f89ea6624b12b9f897e6479e572399e8a26667" alt=""
コメント