コンテンツにスキップ

CloudflareログのJSONデータを解析する

Cloudflareログデータをダウンロードした後、さまざまなツールを使用してログを解析できます。

JSONログデータを解析するために使用されるツールの1つは、_jq_です。_jq_を始めるには、_jq_公式サイトを訪れてください。

フィールドの集計

IPアドレス、URI、リファラーなど、ログに表示されるフィールドを集計するには、いくつかの_jq_コマンドを使用できます。これは、トラフィックのパターンを特定するのに役立ちます。たとえば、最も人気のあるページを特定したり、攻撃をブロックしたりするためです。

以下の例は、フィールド名に一致し、各フィールドインスタンスのカウントを提供し、カウントの昇順でソートします。

Terminal window
jq -r .ClientRequestURI logs.json | sort -n | uniq -c | sort -n | tail
2 /nginx-logo.png
2 /poweredby.png
2 /testagain
3 /favicon.ico
3 /testing
3 /testing123
6 /test
7 /testing1234
10 /cdn-cgi/nexp/dok3v=1613a3a185/cloudflare/rocket.js
54 /
Terminal window
jq -r .ClientRequestUserAgent logs.json | sort -n | uniq -c | sort -n | tail
1 python-requests/2.9.1
2 Mozilla/5.0 (Macintosh; Intel Mac OS X 10_7_5) AppleWebKit/537.17 (KHTML, like Gecko) Chrome/24.0.1312.56 Safari/537.17
4 Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/48.0.2564.116 Safari/537.36
5 curl/7.47.2-DEV
36 Mozilla/5.0 (X11; Linux x86_64; rv:44.0) Gecko/20100101 Firefox/44.0
51 curl/7.46.0-DEV
Terminal window
jq -r .ClientRequestReferer logs.json | sort -n | uniq -c | sort -n | tail
2 http://example.com/testagain
3 http://example.com/testing
5 http://example.com/
5 http://example.com/testing123
7 http://example.com/testing1234
77 null

フィールドのフィルタリング

もう1つの一般的な使用例は、特定のフィールド値のデータをフィルタリングし、その後に集計することです。これにより、「どのURLが最も多くの502エラーを受けたか?」という質問に答えるのに役立ちます。たとえば:

Terminal window
jq 'select(.OriginResponseStatus == 502) | .ClientRequestURI' logs.json | sort -n | uniq -c | sort -n | tail
1 "/favicon.ico"
1 "/testing"
3 "/testing123"
6 "/test"
6 "/testing1234"
18 "/"

Cloudflare WAFによってブロックされた上位のIPアドレスを見つけるには、次のクエリを使用します:

Terminal window
jq -r 'select(.SecurityAction == "block") | .ClientIP' logs.json | sort -n | uniq -c | sort -n
1 127.0.0.1

キャッシュされたリクエストの表示

キャッシュ比率を取得するには、次のクエリを試してください:

Terminal window
jq -r '.CacheCacheStatus' logs.json | sort -n | uniq -c | sort -n
3 hit
3 null
3 stale
4 expired
6 miss
81 unknown

TLSバージョンの表示

訪問者が使用しているTLSバージョンを確認するには、たとえば、TLS 1.2より古いバージョンを無効にできるかどうかを判断するために、次のクエリを使用します:

Terminal window
jq -r '.ClientSSLProtocol' logs.json | sort -n | uniq -c | sort -n
42 none
58 TLSv1.2