カテゴリー: BackEnd

Amazon API Gatewayざっくり概要

はじめに

サービスを開発していく上で、メインの処理とは分けたいけどそれ単体でサーバを建てるほどではないような機能が必要になる事があると思います。そういったケースで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についても調べてみたいと思います。

おすすめ書籍

 

Hiroki Ono

シェア
執筆者:
Hiroki Ono
タグ: AWS

最近の投稿

フロントエンドで動画デコレーション&レンダリング

はじめに 今回は、以下のように…

3週間 前

Goのクエリビルダー goqu を使ってみる

はじめに 最近携わっているとあ…

1か月 前

【Xcode15】プライバシーマニフェスト対応に備えて

はじめに こんにちは、suzu…

2か月 前

FSMを使った状態管理をGoで実装する

はじめに 一般的なアプリケーシ…

3か月 前