こんにちは、ひるたんぬです。
電子レンジ、生活の中に当たり前のように溶け込んでいる存在ですよね。
でも、「レンジ」とはどこからやってきた要素でしょうか?
発明元のアメリカ(英語)でも”microwave (oven)”であり、「レンジ」の要素は見当たりません。。
歴史を辿るとヒントがありました。
電子レンジの加熱原理は、アメリカのレイセオン社によって、レーダー装置の実験中にお菓子がレーダーのマイクロ波によって溶けていることに気が付き、これにヒントを得て、マグネトロンを使った調理器「レーダーレンジ」として製品化されました。
引用:一般社団法人 日本電機工業会「電子レンジの歴史」
「電子レンジ」という言葉もここから生まれたのかも知れないですね¹。
さて、今回はCloudFrontの機能の一つ、Lambda@Edgeにおけるログについて少し紐解いていきます。
やりたいこと
Amazon CloudFrontを使っており、その中でLambda@Edgeを使用しています。
ここで、Lambda@Edgeから出力されるログについて、予めログの有効期限を設定しておきたい場合を考えます。
既定では…
AWSの公式ドキュメントなどにも記載がありますが、Lambda@Edgeでは関数が実行された場所に最も近いAWSリージョンにロググループが自動で作成され、ログイベントが保管されます。
また、自動で作成されるロググループは有効期限が未設定(失効しない)のため、明示的に削除しないとログが残りつづけます。
コンプライアンスや規約上、ログはすべて保管する必要がある場合などはこの設定でも問題はありませんが、ログイベントの保存にも料金は発生します。
課題点
以上のことから、Lambda@Edgeでログを保管する場合、デフォルトの設定では無期限でログが残り続け、主に費用面での負担が増大しかねない点をご説明しました。
では、予めロググループを作成し、ロググループに対して有効期限を設定したいのですが…それにはLambda@Edgeがどこで実行されうるのか(どこのAWSリージョンにログが出力されうるのか)、を知る必要があります。
Lambda@Edgeが実行される場所
これを理解するためには、Amazon CloudFrontについても知る必要があります。
CloudFrontは「エッジロケーション(≠ リージョン)」と呼ばれる場所でキャッシュサーバーとして機能しています。
エッジロケーションにてキャッシュヒットしなかった場合は「リージョン別エッジキャッシュ(≠ リージョン)」にアクセスし、それでもヒットしなかった場合はオリジンからコンテンツを取得します。

引用:AWS Black Belt Online Seminar – Amazon CloudFront 基礎編(P. 15)
そして、Lambda@Edgeは、上記の「リージョン別エッジキャッシュ」にデプロイされています。

引用:AWS Black Belt Online Seminar – Amazon CloudFront (CloudFront Functions / Lambda@Edge 編) (P. 17)
では、その「リージョン別エッジキャッシュ」はどこにあるのでしょうか?
2026年1月現在では13個所に設定されています。
- 米国東部 (バージニア北部) – us-east-1
- 米国東部 (オハイオ) – us-east-2
- 米国西部 (北カリフォルニア) – us-west-1
- 米国西部 (オレゴン) – us-west-2
- アジアパシフィック (ムンバイ) – ap-south-1
- アジアパシフィック (ソウル) – ap-northeast-2
- アジアパシフィック (シンガポール) – ap-southeast-1
- アジアパシフィック (シドニー) – ap-southeast-2
- アジアパシフィック (東京) – ap-northeast-1
- 欧州 (フランクフルト) – eu-central-1
- 欧州 (アイルランド) – eu-west-1
- 欧州 (ロンドン) – eu-west-2
- 南米 (サンパウロ) – sa-east-1
- Amazon CloudFront 用のリージョン別エッジキャッシュを発表
- サービスアップデート Edge Networking Services 編
└ P.8 - Amazon CloudFront が AWS の欧州 (アイルランド) リージョンで新しいリージョン別エッジキャッシュを開始
また、CloudFrontのユーザーマニュアルからもLambda@Edgeのサービスにリンクされたロールの使用がサポートされているリージョンにて、同様のものを挙げています。
デベロッパーガイド – Amazon CloudFront
└ P. 935(「Lambda@Edge サービスリンクロールでサポートされている AWS リージョン 」)にリージョン一覧の記載があります。
以上のことから、すべてのAWSリージョンでリージョン別エッジキャッシュが提供されているわけではないことが分かりました。(例えば、大阪リージョンでは提供されていないことが分かりやすいかと思います。)
結論
以上のことから、予めロググループを作成し、ロググループに対して有効期限を設定したい場合は、上述しました13個のリージョンに対して、所定の命名規則や設定に沿ったロググループを作成すれば良い、ということになります。
Lambda@Edgeにおけるロググループ名の規則については、以下をご参照ください。
終わりに
今回は、CloudFrontにLambda@Edgeを組み合わせて使用する場合において、どのリージョンにロググループが必要なのか(≒ Lambda@Edgeの実行に関連するAWSリージョンがどこなのか)調査しご紹介しました。
公式ドキュメントなどでも言及がほとんどされておらず情報収集に苦戦しましたが、参考になる方がいらっしゃいましたら幸いです。
余談ですが、「レンジでチン」という言葉は死語になってしまう日もくるのでしょうか。
テレビにおける「チャンネル回す」も死語になりつつあるようです…
最近の電子レンジは、「ピー」という音がなったり、おしゃれな音楽が流れるようです。「レンジでピー」…?
