はじめに
サービスを開発していく上で、メインの処理とは分けたいけどそれ単体でサーバを建てるほどではないような機能が必要になる事があると思います。そういったケースでAmazon API Gatewayが使えないかと思い、どのようなサービスなのか調べてみました。
Amazon API Gatewayとは?
そもそもGatewayとはなにかというと、「玄関」や「入口」を表す英単語ですが、ITの分野においてはプロトコルの異なるネットワークを中継する機能や、そのような機能を持つ機器を指す言葉のようです。
Amazon API Gatewayは 「API Gateway」の名前の通り、ユーザからのHTTPリクエストを受けてそれをAWS Lambdaを始めとする様々なリソースに振り分けることができます。
なにができる?
Amazon API Gatewayの機能について詳しく見ていきます。
AWSのDeveloper Guideによると、
Amazon API Gateway is an AWS service for creating, publishing, maintaining, monitoring, and securing REST, HTTP, and WebSocket APIs at any scale. API developers can create APIs that access AWS or other web services, as well as data stored in the AWS Cloud. As an API Gateway API developer, you can create APIs for use in your own client applications. Or you can make your APIs available to third-party app developers. For more information, see Who uses API Gateway?.
とあるように、Amazon API GatewayはAPIの作成から公開、保守、監視までの一連の機能を提供します。
作成できるAPIの種類
Amazon API Gatewayで作成できるAPIの種類は大きく3つあります。
- HTTP API
- REST API
- WebSocket API
そして、これらのAPIではAWSや他のWebサービス、AWSに保存されている(RDSやS3などの)データにアクセスすることができます。
Amazon API Gatewayでは以下のようなRESTful APIを作成することができます。
- HTTPベースであること
- ステートレスなクライアントサーバ通信であること
- HTTPメソッドがGET、POST、PUT、PATCH、DELETEのいずれかであること
また、今回は詳しく紹介しませんが、WebSocket APIの方は以下のような感じです。
- WebSocketプロトコルに準拠するクライアントとサーバ間のステートフルな全2重通信
- メッセージの内容に基づいて、受信メッセージをルーティングする
REST APIとHTTP APIの違い
REST APIとHTTP APIはどちらもRESTfulなAPIを提供します。これらの違いとしては機能面と価格面です。
REST APIはHTTP APIよりも多くの機能をサポートしていますが、その分HTTP APIよりも料金が高くなっています。具体的にはHTTP APIは、APIキー、クライアント単位でのスロットリング、リクエスト検証、AWS WAFとの統合、プライベートAPIエンドポイントなどの機能がありません。これらの機能が必要な場合はREST APIを選択し、不要であればHTTP APIを選択すると良いようです。
機能面での差異を詳しく知りたい方はこちらをご覧ください。
Amazon API Gatewayのユースケース
REST API
API Gateway REST APIはリソースとメソッドで構成されています。ここでいうリソースはアプリがリソースパスを通じてアクセスすることができる論理的な実態で、メソッドはAPIの利用者が送信するREST APIリクエストとその結果返されるレスポンスに対応しています。
例えば、サービスを使用するユーザの収入を表す
/incomes
というリソースパスにGETでリクエストした場合はそのユーザの収入をレスポンスとして返却しますが、同じリソースにPOSTでアクセスした場合はそのユーザに対して新たに収入を追加することができます。
その際、データがどこに保存されているかは重要ではありません。データの保存元がRDSだろうがDynamoDBだろうがやることは変わりません。このAPIの開発者は受信したメソッドリクエストとデータの保存先とのマッピング、必要なIAMポリシーや入出力データの変換方法などを設定します。
HTTP API
HTTP APIはREST APIよりも低レイテンシーかつ低コストでRESTful APIを作成することができます。
例えば、Lambda関数と統合するHTTP APIを作成することができます。クライアントがAPIを呼び出すとAPI GatewayはLambda関数にリクエストを送信し、その関数のレスポンスをクライアントに返却します(Lambda関数との連携はREST APIでも可能です)。
また、HTTP APIはOpenID ConnectとOAuth 2.0の認証に対応しています。
さいごに
ざっくりですがAmazon API Gatewayについて調べてみました。API Gateway単体で使うというよりはAWS Lambdaと組み合わせて使われるケースが一般的だと思いますので、Lambdaについても調べてみたいと思います。