ネットワークの障害切り分けを目的に、Fortigateを通過するパケットをキャプチャすることができます。 パケットキャプチャはGUI/CLIから取得できます。
data:image/s3,"s3://crabby-images/fb797/fb79723ab57b8db8fb2e57f10b6970adbbc79c11" alt=""
GUIでの取得
port2を通過するパケットを取得します。 GUIで、ネットワーク >> パケットキャプチャ >> 新規作成を選択します。
data:image/s3,"s3://crabby-images/d0f61/d0f61fc4a5e4c7ff9a7a98135c7cb93c5e661a9f" alt=""
すると下のような画面に遷移します。
data:image/s3,"s3://crabby-images/915db/915db3323413834f8b99e91acfb773d4054c351e" alt=""
インタフェースで、通過パケットを取得したいインタフェースを指定します。今回は、port2 (LAN(port2))を指定します。
data:image/s3,"s3://crabby-images/0e2bf/0e2bf1c4954d9cf2db74b56ab90561b7879855d5" alt=""
最大キャプチャパケット数は、デフォルト4000のままとします。キャプチャ数に制限があるため、通常はIPアドレスやポート番号をフィルタして取得するのが望ましいです。
今回は、端末の10.0.200.100にフィルタするものとします。 フィルタを有効にして、ホストに10.0.200.100を入力し、OKをクリックします。
data:image/s3,"s3://crabby-images/18ef6/18ef682cd053b740aa75ff37ac8465df4671d938" alt=""
以下のような画面となります。これではまだ、キャプチャは開始されていません。
data:image/s3,"s3://crabby-images/789ca/789ca9e9b4d09dc153b30c5f0d6399d178178ad8" alt=""
LAN(port2)をダブルクリックします。キャプチャ中という項目が増えています。▶︎の再生マークをクリックします。
data:image/s3,"s3://crabby-images/eeb05/eeb0514b23a5828c26e8c7d0c060b93a63a31b7c" alt=""
キャプチャが開始され、最大キャプチャパケット数の何パーセントが取得されているか確認できます。停止するには、■をクリックします。
data:image/s3,"s3://crabby-images/e2712/e27124b77917608ddb95d685122b092b0a0002a6" alt=""
停止後、ダウンロードボタンをクリックすると、pcapファイルが取得できます。
data:image/s3,"s3://crabby-images/abec7/abec7a195830961817e527aff84070a37b2a8db2" alt=""
ファイル名として、port2.root.1.pcapというファイルがダウンロードされます。
data:image/s3,"s3://crabby-images/a5354/a53544adb50eb294cc81aadcca290c07b2f1b302" alt=""
pcapファイルをWireSharkで開くと、キャプチャデータが参照できます。
data:image/s3,"s3://crabby-images/e6982/e6982ebbf794cc02d9aeb967f681719fb6a020c8" alt=""
CLIでの取得
CLIでは、パケット全体ではなく、送信元や宛先、プロトコルなどを条件にパケットが通過しているのか否か、ヘッダ情報のトレースをすることができます。
下記、記事を参考に、キャプチャの動作を確認しました。
>> 参考記事 : Troubleshooting Tip: Using the FortiOS built-in packet snifferdiagnose sniffer packet <インタフェース> “<フィルタ条件>” <詳細レベル> <取得回数> <タイムスタンプ>
- インタフェース:取得するインタフェースを指定します。すべてのインタフェースを指定する場合はany
- フィルタ条件:取得するパケットの条件(IP、プロトコルなど)を定義します。”none”とすると、条件を指定しない(全てパケット)となります。
- 詳細レベル(Verbose levels):情報取得のレベル(1〜6)を定義します。私がよく使用するのは、4 です。どのインタフェースにパケットが入って、どのインタフェースから出力しているのかがトレースでき、便利です。
Verbose levels in detail:
1: print header of packets
2: print header and data from ip of packets
3: print header and data from ethernet of packets (if available)
4: print header of packets with interface name
5: print header and data from ip of packets with interface name
6: print header and data from ethernet of packets (if available) with intf name
https://community.fortinet.com/t5/FortiGate/Troubleshooting-Tip-Using-the-FortiOS-built-in-packet-sniffer/ta-p/194222?externalID=11186
- 取得回数:取得するパケット数。指定しない、もしくは0の場合は、無制限となり、Ctrl+Cで停止させます。
- タイムスタンプ:フォーマットを指定。a: UTC時刻表示 l (Lの小文字): ローカル時刻表示
インタフェース指定
すべてのインタフェースを通過するICMPパケットをキャプチャ(詳細レベル4)
diagnose sniffer packet any “icmp” 4
data:image/s3,"s3://crabby-images/ea2bf/ea2bf77ea60261844f8a39ecf8ef5e817fff5e22" alt=""
port2を通過するICMPパケットをキャプチャ(詳細レベル4)
diagnose sniffer packet port2 “icmp” 4
data:image/s3,"s3://crabby-images/31de0/31de0e971897ddafe7629bba9394635903a80b10" alt=""
詳細レベル
レベル1
パケットのヘッダサマリ情報のみ表示。
data:image/s3,"s3://crabby-images/bdd0a/bdd0a664a88611967a27b7245615fdea14ff1606" alt=""
レベル2
パケットのヘッダサマリとIPヘッダとデータ部分を表示
data:image/s3,"s3://crabby-images/c0918/c091890c236ee71e1912e91610c8380f74e57111" alt=""
レベル3
パケットのヘッダサマリとイーサヘッダ、IPヘッダとデータ部分を表示
data:image/s3,"s3://crabby-images/aa5f0/aa5f0a5da17503008de0b5b8f3e2a6986120458d" alt=""
レベル4
パケットのヘッダサマリとインタフェース情報を表示
data:image/s3,"s3://crabby-images/db25b/db25bd5fc3be4647b56d3f0fb6349d6f2d91179a" alt=""
レベル5
パケットのヘッダサマリとインタフェース情報にIPヘッダ、データ部分を表示
data:image/s3,"s3://crabby-images/39f47/39f471fc6495304c99e8fd714933f6fe7238e141" alt=""
レベル6
パケットのヘッダサマリとインタフェース情報にイーサヘッダ、IPヘッダ、データ部分を表示
data:image/s3,"s3://crabby-images/98aab/98aab4c2f05adc27c2ba758879af960b297ad175" alt=""
取得回数
詳細レベル1で4パケットを取得。
diagnose sniffer packet any “icmp” 1 4
data:image/s3,"s3://crabby-images/8631b/8631b4c898262cd882f63714ba73e61a78a8f3d9" alt=""
タイムスタンプ
UTC時刻表示(a)
diagnose sniffer packet any “icmp” 1 0 a
data:image/s3,"s3://crabby-images/1876f/1876fbbf9493a3c8634c9d1aea31ddd4bc82944d" alt=""
ローカル時刻表示(l:Lの小文字)
diagnose sniffer packet any “icmp” 1 0 l
data:image/s3,"s3://crabby-images/40bf9/40bf93a90700707ca93120e1fb2d8871bed13a81" alt=""
よく使用するキャプチャ
すべてのインタフェースですべてのパケット
diagnose sniffer packet any none 4
data:image/s3,"s3://crabby-images/00d2e/00d2e243e9c15accb335bdfb88f8fca18c43f64b" alt=""
ホスト間の特定プロトコル通信
10.0.200.100と8.8.8.8間のICMPパケット。複数条件は、and や or で記述します。
diagnose sniffer packet any ” host 10.0.200.100 and host 8.8.8.8 and icmp” 4
data:image/s3,"s3://crabby-images/f779c/f779c96dc682b0689e412cbf3c6af07682ac67d6" alt=""
送信元、宛先アドレスを指定
送信元10.0.200.100 宛先 8.8.8.8のICMPパケット。
diagnose sniffer packet any “src host 10.0.200.100 and dst host 8.8.8.8 and icmp” 4
data:image/s3,"s3://crabby-images/7121b/7121b1181d1ae9605f8974697812d78362a8040e" alt=""
ネットワークセグメントを指定
10.0.200.100と216.58.192.0/19間のICMPパケット。
diagnose sniffer packet any ” host 10.0.200.100 and net 216.58.192.0/19 and icmp” 4
data:image/s3,"s3://crabby-images/08d6f/08d6f0dc31b57c0c1841c284bce40b01994a7c0b" alt=""
すべてのTCPパケットを指定
10.0.200.100と216.58.192.0/19間のTCPパケット。
diagnose sniffer packet any ” host 10.0.200.100 and net 216.58.192.0/19 and tcp” 4
data:image/s3,"s3://crabby-images/c5f2f/c5f2fae4de34c65fb6d8712fc7374acee3e502f2" alt=""
TCPポート番号を指定
10.0.200.100と216.58.192.0/19間のTCPポート番号443のパケット。
diagnose sniffer packet any ” host 10.0.200.100 and net 216.58.192.0/19 and tcp port 443″ 4
data:image/s3,"s3://crabby-images/51640/516409108007f9a4f5dd4c72f76df0dd29588ccb" alt=""
TCPフラグ(SYN・RST)
TCPヘッダで、”先頭何バイト目の値がいくつか”を指定して、条件設定します。例えば、TCPフラグ(SYNやRSTなど)は、TCPヘッダを0からはじめて13番目の1バイトの中に含まれます。
data:image/s3,"s3://crabby-images/05b17/05b175c172ba7beb768fc031ad9774829e4c0c19" alt=""
TCPのRSTパケット
TCPヘッダ13番目の1バイトと4 ( 上の図でいうRSTフラグのみ1にした1バイト(00000100) )の論理積が0でないので、RSTのビットが1である条件となります。
diagnose sniffer packet any “tcp[13] & 4 != 0”
data:image/s3,"s3://crabby-images/e664b/e664b1333df51b75e2c22ec93b91b41e8208887f" alt=""
TCPのSYNパケット
RSTフラグ同様に、SYNフラグのみ1にした1バイト(00000010))の論理積が0でない条件とします。
diagnose sniffer packet any “tcp[13] & 2 != 0”
data:image/s3,"s3://crabby-images/ff973/ff9737c06b69aec1d9b47834e5675c82cb072eb6" alt=""
TCP のSYN ACKフラグ
SYN/ACKの場合は、SYNが2、ACKが16 の合計18であるため、tcp[13]の値が18であることを条件とします。
diagnose sniffer packet any “tcp[13] = 18”
data:image/s3,"s3://crabby-images/98323/98323bf07cb9eeda42af87c699f6705ca6702698" alt=""
コメント