この記事は、「Relic Advent Calendar 2022」の3日目の記事です!
前置き
re:Invent 2022が無事終わりましたね。
今年はコロナ禍もあってなんと3年ぶりにラスベガス現地で開催され、Twitterのタイムラインからは現地組の様子を伺えたこともあって現地の雰囲気を感じながら私もkeynoteを中心にオンラインで参戦しました。夜はre:Invent、昼はAWSのシニアエバンジェリスト亀田さんによるre:Capで補完、最終日昼にBlackBelt Onlineで総復習とキャッチアップに勤しんだ1週間だったと思います。
今年のre:Inventで発表されたアップデートは126個と、毎年の事ながらですが大量に投下されました。
何処が発祥かは不明ですがJAWS-UGには「アウトプットしないのは知的な便秘」という言葉が流行っており、このままでは体調不良を起こしてしまうので私も気になったサービスや新機能を自分で実際に検証して、その内容を書いていこうと思います。
他所さんが後々整理した物を書いてくれるでしょって心の声も聞こえたりしますが、自分で一次情報拾って試していく事に一定の価値があると思っているのと、多くの人が手を動かしてアウトプットする事で、知見だけじゃなく熱量も繋いでいけると思うので、多少内容被っても気にしないスタイルで書いていきます!
Amazon EventBridge Pipesとは
さて、第一弾として「Amazon EventBridge Pipes」について書いていこうと思います。
EventBridge PipesとはEventBridgeの新機能で、イベントプロデューサーと呼ばれるイベントのソース元から、イベント情報をフィルタリングや強化(Enrichment)で変換した後に、コンシューマーと呼ばれるターゲットに配信してくれる仕組みです。
また、それらの順序性を維持して処理できるというのが大きなポイントになります。
プロデューサーがDynamoDBStreamやKinesis、SQS、MQ、Apache Kafkaなど限定されているのはこの為かもしれません。
プロデューサーに対応しているサービス
- Amazon DynamoDB Stream
- Amazon Kinesis Data Streams
- Amazon SQS
- Amazon Managed Streaming for Apache Kafka
- Amazon MQ
- セルフマネージド Apache Kafka
コンシューマーに対応しているサービス
- Amazon Step Functions
- Kinesis Data Streams
- Kinesis Data Firehose
- AWS Lambda
- EventBridge
- API Gateway
- CloudWatch logs
- ECS Cluster
- Inspector
- Redshift Cluster
- SageMaker pipeline
- Amazon SQS
- Amazon SNS
- AWS Batch
EventBridge Pipes上の「強化(Enrichment)」に対応しているサービス
- EventBridge
- AWS Lambda
- API Gateway
- Amazon Step Functions
EventBridgeイメージ
これまでのEventBridgeとはどう違うのか理解するため、EventBridgeについて改めて復習しますと、EventBridgeはかなりざっくり言うと以下の3つのフローで構成されています。
- イベントソースからイベントの受信
- フィルタリング
- ターゲットへ配信
EventBridgeが対象とするイベントソースは以下を見て分かる通り、AWSサービスだけでも多岐に渡ります。その他にも、DataDogやAuth0、Shopify、Stripeなどの30を超えるSaaS連携にも対応しています。
| 対応サービス | 配信タイプ |
|---|---|
| Amazon AppFlow | ベストエフォート |
| Application Auto Scaling | ベストエフォート |
| AWS Application Cost Profiler | ベストエフォート |
| Amazon Athena | ベストエフォート |
| AWS Backup | ベストエフォート |
| AWS Batch | 保証付き |
| Amazon Braket | 保証付き |
| AWS Private Certificate Authority | ベストエフォート |
| Amazon Chime | ベストエフォート |
| AWS CloudFormation | ベストエフォート |
| AWS CloudTrail からのイベント | ベストエフォート |
| Amazon CloudWatch | 保証付き |
| AWS CodeArtifact | 保証付き |
| AWS CodeBuild | ベストエフォート |
| AWS CodeCommit | ベストエフォート |
| AWS CodeDeploy | ベストエフォート |
| AWS Config | ベストエフォート |
| Amazon Connect | ベストエフォート |
| AWS Control Tower | ベストエフォート |
| AWS Data Exchange | ベストエフォート |
| Amazon Data Lifecycle Manager | ベストエフォート |
| AWS DataSync | ベストエフォート |
| Amazon DevOps Guru | ベストエフォート |
| AWS Elastic Beanstalk | ベストエフォート |
| Amazon Elastic Block Store | ベストエフォート |
| Amazon Elastic Block Store ボリュームへの変更 | ベストエフォート |
| Amazon Elastic Compute Cloud (Amazon EC2) | ベストエフォート |
| Amazon EC2 Auto Scaling | ベストエフォート |
| Amazon EC2 フリート | ベストエフォート |
| Amazon EC2 スポットインスタンスの中断 | ベストエフォート |
| Amazon Elastic Container Registry | ベストエフォート |
| Amazon Elastic Container Service | 保証付き |
| AWS Elemental MediaConvert | 保証付き |
| AWS Elemental MediaLive | ベストエフォート |
| AWS Elemental MediaPackage | ベストエフォート |
| AWS Elemental MediaStore | 保証付き |
| Amazon EMR | ベストエフォート |
| Amazon EMR Serverless | ベストエフォート |
| Amazon EventBridge のスケジュールされたルール | 保証付き |
| Amazon GameLift | ベストエフォート |
| AWS Glue | ベストエフォート |
| AWS Glue DataBrew | ベストエフォート |
| AWS Ground Station | ベストエフォート |
| AWS Health | ベストエフォート |
| Amazon Inspector | ベストエフォート |
| Amazon Interactive Video Service | ベストエフォート |
| AWS IoT Analytics | 保証付き |
| AWS IoT Greengrass V1 | ベストエフォート |
| AWS IoT Greengrass V2 | ベストエフォート |
| AWS Key Management Service CMK の削除 | 保証付き |
| AWS Key Management Service CMK のローテーション | ベストエフォート |
| AWS Key Management Service でインポートされたキーマテリアルの有効期限切れ | ベストエフォート |
| Amazon Location Service | 保証付き |
| Amazon Macie | ベストエフォート |
| Amazon Managed Blockchain | ベストエフォート |
| AWS Managed Services | ベストエフォート |
| Amazon OpenSearch Service | ベストエフォート |
| AWS OpsWorks | 保証付き |
| AWS Proton | ベストエフォート |
| Amazon QLDB | 保証付き |
| Amazon RDS | ベストエフォート |
| Amazon Redshift | 保証付き |
| AWS Resource Access Manager | ベストエフォート |
| Amazon SageMaker | ベストエフォート |
| Savings Plans | ベストエフォート |
| AWS Security Hub | 保証付き |
| AWS Signer | 保証付き |
| Amazon Simple Storage Service (Amazon S3) | 保証付き |
| Amazon Simple Workflow Service | ベストエフォート |
| AWS Step Functions | ベストエフォート |
| AWS Storage Gateway | 保証付き |
| AWS Support | ベストエフォート |
| AWS Systems Manager | ベストエフォート |
| リソースのタグ変更 | ベストエフォート |
| AWS Transit Gateway | ベストエフォート |
| Amazon Translate | 保証付き |
| AWS Trusted Advisor | ベストエフォート |
| Amazon WorkSpaces | ベストエフォート |
EventBridgeとの違い
一方で、EventBridge Piplesにおけるプロデューサーは一部のAWSサービスに限定され、フィルタリングだけでなく間に強化(Enrichment)ステップを挟んでLambdaやStepFunctionなどで処理した後に、コンシューマーへの配信を可能することで、イベントドリブンなアプリケーション開発を支援してくれます。
また、それら順序立った一連の流れをコードを書くことなく構築する事が可能なので、コード記述の開発時間を短縮できるのも大きいポイントになります。
EventBridge Pipesの構築方法
EventBridge Pipesは以下の方法で構築できます。
- AWSコンソール
- CLoudFormation
- CDK
※CDKに対応しているのは嬉しいですね!
対応リージョン(2022年現在)
以下の2リージョン以外の商用リージョンで利用可能です。
非対応リージョン(2022年現在)
- アジアパシフィック(ハイデラバード)
- ヨーロッパ(チューリッヒ)
料金(東京リージョン)
| 条件 | 価格 |
|---|---|
| フィルタリング後リクエスト数 | 100万回で$0.50 |
※ペイロードの64KBで1つの要求として課金される。
例えば、256KBのペイロードを持つイベントバッチは4つの要求として課金
例
送信されるイベント数: 20,000,000
フィルタリング条件に合致するイベント: 50%
リクエスト毎に5つのイベントとして処理
フィルタリング後のリクエスト数: 20,000,000 * 0.5/5 = 2,000,000
コスト: 2M * 0.5ドル = 1ドル
EventBridge Pipesを構築
ドキュメントにはCloudFormationやCDKに対応と明記されていましたが、まだリリースされていないようだったのでコンソールから実際に触ってみました。
今回は扱いに慣れるため簡単な、DynamoDB→フィルタリング→CloudWatchlogsのパターンでやってみようと思います。慣れてきたら強化(Enrichment)ステップも挟んだ処理を試してみようと思います。
DynamoDB(プロデューサー)の用意
DynamoDBを以下の設定値で用意
| 項目 | 設定値 |
|---|---|
| パーティションキー | id |
| ソートキー | Message |
| DynamoDBストリーム | 有効 ※必須 |
EventBridge Pipe構築
- コンソールより「パイプの作成」を押下
- パイプ構築画面の「イベントソース」をクリック
- 詳細のイベントソース選択より「DynamoDB」を選択
- DynamoDBストリーム選択より事前に用意した物を選択
- イベントのフィルタリングを選択
- サンプルイベントタイプで「Enter my own」を選択して以下を入力
{
"eventID": "1",
"eventVersion": "1.0",
"dynamodb": {
"Keys": {
"Id": {
"N": "101"
}
},
"NewImage": {
"Message": {
"S": "Sample"
},
"Id": {
"N": "101"
}
},
"StreamViewType": "NEW_AND_OLD_IMAGES",
"SequenceNumber": "111",
"SizeBytes": 26
},
"awsRegion": "us-east-1",
"eventName": "INSERT",
"eventSourceARN": "arn:aws:dynamodb:us-east-1:111122223333:table/EventSourceTable",
"eventSource": "aws:dynamodb"
}
{
"dynamodb": {
"NewImage": {
"Message": {
"S": [{
"prefix": "Sample"
}]
}
}
}
}
- ターゲットを選択して、ターゲットサービスで「CloudWatch logs」を選択
- ロググループに任意のロググープを選択
- 追加設定で任意のログストリーム名を入力
- 画面上部にてパイプ名を入力して「パイプを作成」をクリック
動作確認
- プロデューサーとなるDynamoDBにて項目を以下の値で作成
- Sampleではログが出力され、Exampleではログが出力されない
| パーティションキー | 値 | ソートキー | 値 |
|---|---|---|---|
| id | 1 | Message | Sample |
| id | 2 | Message | Example |
今回、一先ず一連の流れを汲んだPipeが動作されたことが確認できました。
おまけ1
どうして…
おまけ2
まだ日本語の公式ドキュメントが更新されていないため、EventBridgePipesについて調べたい時はEnglish Verを見に行く必要があります。
今後の予定
re:inventのkeynoteではEventBridge Pipesの今後の予定についても触れられていましたのでご紹介します。
- CloudWatch logsへのサポート
- 現状CloudWatchメトリクスでパイプの呼び出しと失敗のみ確認可能
- VPCエンドポイント/プライベートリンクへのサポート
- AWS SDKへのサービス統合
- アカウント間連携
- アーカイブとリプレイのサポート
- SAMとCDK(L2)/IDEへのサポート
どれも待ち遠しいですね!!
まとめ
EventBridgeやStepFunctionなどの対応サービス拡張や機能追加などここ1年で特に進化しており、keynoteで発表されたこともあってイベントドリブンなサーバーレスアプリケーション開発がAWSとって大きなテーマの1つでトレンドなんだなと感じました。
引き続きアップデートされたサービスや機能について気になったものを検証して書いていきたいと思います!






