data:image/s3,"s3://crabby-images/f42c3/f42c38a1e75536bbb0223a4aaffbf88f5c18e039" alt="New Relic estimate data cost conceptual graphic"
はじめに
去る2022年12月15日、Google CloudのVPC flow logsとの連携サポートが発表されました。
本機能の大きな特徴は次の4つです。
- New Relic で VPC 内のネットワークトラフィックを監視し、アラートできる
- 毎秒のバイトやパケット、各 TCP または UDP ポートの毎秒のアクセプトやリジェクトなどのネットワークパフォーマンスメトリクスを視覚化できる
- フローログの偏差を調査し、ネットワークのボリュームや健全性における予期せぬ変化を追跡できる
- 過度に制限されたセキュリティ・グループ・ルールや悪意のあるトラフィックの可能性のある問題を診断できる
これから、実際に設定し、使うまでの流れを解説します。
事前準備
本記事では実際にUIより提供される操作手順にあわせ、Google Cloud側の設定はCLIで行います。 あらかじめterminalなどでgcloudコマンドが実行できるよう設定しましょう。
※CLIとは別にterraformによる設定手順も提供されます。ご自身が管理する環境に合わせ、選択ください。
VPC flow logsのログ転送ではCloud Pub/Sub及びCloud Dataflowを利用します。 APIが有効になっていない場合は、あらかじめ有効にします。
参考画像:VPC Flow Logs ログ連携アーキテクチャ
data:image/s3,"s3://crabby-images/4c6cc/4c6ccb9b6f818510c09b76704e4237ae8699b6aa" alt="flowlog"
両サービスはCLIから下記のコマンドで有効化できます。
gcloud services enable pubsub
gcloud services enable dataflow
data:image/s3,"s3://crabby-images/77f56/77f569fa60a08314fa563aa16105d168cb831919" alt="flowlog03"
- Select your data よりGCP VPC Flow Logsを選択
data:image/s3,"s3://crabby-images/2b0a6/2b0a6c52c09b8be8da753a5ff5c5f386dc802c57" alt="flowlog04"
- GCP Projectに対象となるgcp project idを、Regionに対象リージョンをそれぞれ設定
data:image/s3,"s3://crabby-images/74ea7/74ea7b0a9d60460346ec77823940b04a50a9d352" alt="flowlog04"
- VPC flow logsの有効化
data:image/s3,"s3://crabby-images/ae7ae/ae7ae3496f9d510ef3cd8ce037f18c4739c286c6" alt="flowlog05"
提示されたcommandを実行し、対象リージョンにあるsubnetのVPC flow logsを有効化します。
※提示されたcommandのうち、SUBNET_NAME, (AGGREGATION_INTERVAL, SAMPLE_RATE)はそれぞれ手動で記入する必要があります。
SUBNET_NAME: 対象サブネット名
AGGREGATION_INTERVAL: インターバル(デフォルト 5秒)
SAMPLE_RATE: ログのサンプリングレート(デフォルト 50%)
※データの流量が多くおおまかな情報が取れれば良い場合はデフォルトの50%で、セキュリティ上詳細な情報が欲しいなど要件に応じて割合を調整しましょう
data:image/s3,"s3://crabby-images/96df6/96df6ebf57e31c2aac91f4826521b0ac6ed4b8bc" alt="flowlog06"
- Cloud LoggingからCloud Pub/SubへのSinkを設定
data:image/s3,"s3://crabby-images/8205e/8205e0e6f94a55e420cf90f65ae28a442494ac3e" alt="flowlog07"
今回の例では、一つのsubnetのみを対象とします。
Flow Log Filter Template: A Subnet を選択します。
Subnet Name: 対象のsubnet_nameを入力します。
※Sink Filterのcommandが表示されますが、確認用となり手順5の段階では使用しません。
data:image/s3,"s3://crabby-images/f82e3/f82e3faa1951a0aa49b1a4b1290a17a2a18a3c2c" alt="flowlog08"
- Pub/Subのリソース作成
data:image/s3,"s3://crabby-images/3b4e4/3b4e4e7ae2f8081d7c2ffe05a8af961284036eb9" alt="flowlog009"
表示されたcommandを実行し、Topic及びSubscriptionを作成します。
data:image/s3,"s3://crabby-images/364f9/364f91a4a675edbaf24d53f101f5bc00f3a2d401" alt="flowlog10"
- LoggingのSinkを作成
data:image/s3,"s3://crabby-images/717b0/717b0f0a506e4cb8885954d05546b0f10f0c0e85" alt="flowlog11 (1)"
LoggingからPub/Subへ転送するルールを作成します。
data:image/s3,"s3://crabby-images/e6b72/e6b726f6aff4651885a1ef97d45d170367917ca5" alt="flowlog12"
- Pub/Subのpermissionを設定
data:image/s3,"s3://crabby-images/39287/39287df3baf9c61be92faa237cb9dcd84aab0687" alt="flowlog13"
data:image/s3,"s3://crabby-images/77bc9/77bc9010af79c7482f797b979d0e22b1dabcf560" alt="flowlog14"
表示されたcommandを実行し、返ってきた結果 "serviceAccount:p************-*****@gcp-sa-logging.iam.gserviceaccount.com" を Copy the writer identity from the above command here.にペーストします。
data:image/s3,"s3://crabby-images/4ecc0/4ecc0819394be19f60c8530b3795607ecc5539ab" alt="flowlog15"
それぞれcommandを実行し、service accountが補完された形でjsonに吐き出されますので、ポリシーとして設定します。
- Dataflow jobの作成
data:image/s3,"s3://crabby-images/8eddb/8eddb9f2d6edfb20682c4d55a2e2b8e35f44297b" alt="flowlog16"
commandを実行し、Dataflow jobを作成します。
data:image/s3,"s3://crabby-images/01bf3/01bf3685abde677cf144e2db2108153d4df6f485" alt="flowlog17"
以上で設定は完了です。
ここまで正常に実行できていれば、Google CloudのWebコンソールなどで対象のDataflow jobのStatusがRunningとなり、JOB GRAPHでもデータが流れていることを確認できます。
data:image/s3,"s3://crabby-images/fef28/fef28f259b08bd61cd8dcd993f27e023c3d8020f" alt="flowlog18"
それでは、実際にどのようにビジュアライズされるか見ていきましょう
GCP VPC Flow Logs
data:image/s3,"s3://crabby-images/1206b/1206b462e6144766667fe87ab0a365c6eb19d0f8" alt="flowlog19"
画面中央丈夫のConversationsはデフォルトでsource ip、subnet、dest ipの情報が可視化されます。
この図では一番上のsource ipからのトラフィックが大半を占めているということが一目でわかるかと思います。
まとめ
ConversationsではportなどVPC Flow Logに含まれるさまざまな情報も含めて可視化することができます。
例えば「特定のVMに対してのみとあるプロトコルのトラフィックが集中している」ようなケースでも直感的に見分けることの助けとなります。
その他にもTotal Trafficをはじめとしたグラフ類やログなどさまざまな情報がひとつの画面に収められています。
VPC Flow Logをご活用いただき、ネットワークを起点にボトルネックの検出やMTTxの短縮など幅広い分野でご活用いただけますと幸いです。
次のステップ
New Relicをまだお使いでない場合には、無料でNew Relicを使い始めることができます。無料アカウントには、毎月100GBの無料データ取込み、1名の無料フルアクセスユーザー、および無制限の無料ベーシックユーザーが含まれます。
本ブログに掲載されている見解は著者に所属するものであり、必ずしも New Relic 株式会社の公式見解であるわけではありません。また、本ブログには、外部サイトにアクセスするリンクが含まれる場合があります。それらリンク先の内容について、New Relic がいかなる保証も提供することはありません。