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についても調べてみたいと思います。

おすすめ書籍

AWS運用入門 押さえておきたいAWSの基本と運用ノウハウ AWSコスト最適化ガイドブック

blog-page_footer_336




blog-page_footer_336




-BackEnd
-

執筆者:


comment

メールアドレスが公開されることはありません。 が付いている欄は必須項目です

CAPTCHA


関連記事

js

Moment Timezoneを使ってJavaScriptで日付を変換する

1 はじめに2 Moment Timezone2.1 セットアップ2.2 使用例3 Moment Timezoneの機能3.1 タイムゾーンの一覧を表示する3.2 現在のタイムゾーンを表示する3.3 ...

laravel logo

Laravelの基礎知識

1 はじめに2 Laravelの概要2.1 学習コストが低い2.2 Symfonyがベース2.3 DIを積極的に活用している3 ディレクトリ構成3.1 app3.2 bootstrap3.3 conf ...

crypto

公開鍵暗号の概要、用語と使用例

1 はじめに1.1 前提条件2 暗号化と復号2.1 暗号化とは2.2 復号とは3 暗号化方式3.1 共通鍵暗号3.2 公開鍵暗号4 署名と検証4.1 署名とは4.2 検証とは5 RSA暗号とは5.1 ...

laravel logo

Laravelのバリデーションtips

1 はじめに2 配列のバリデーションでRule::uniqueを使う時のカラム名を指定したい3 配列バリデーションのエラーメッセージ制御4 カスタムバリデーションで、他の属性名を参照したい5 番外:複 ...

rails

RailsでAjax処理で画面を更新する

1 はじめに2 View(遷移元)の設定3 Controllerの実装4 View(遷移先)の実装5 参考6 さいごに はじめに RailsでAjax処理で画面を更新する方法を簡単に紹介します。 Vi ...

フォロー

blog-page_side_responsive

2023年4月
 1
2345678
9101112131415
16171819202122
23242526272829
30  

アプリ情報

私たちは無料アプリもリリースしています、ぜひご覧ください。 下記のアイコンから無料でダウンロードできます。