2
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

Amazon ECS で動作する OpenAI Realtime API を使った ChatBot を ロードバランサー で TLS 対応にする

Last updated at Posted at 2025-02-23

1. はじめに

Amazon ECS を利用して OpenAI の Realtime API(WebSocket)を動作させ、ALB を使って TLS(WSS)対応した セキュアな WebSocket チャットボットを構築する。

前回の記事では Amazon ECS で OpenAI Realtime API (WebSocket) を使った ChatBot を構築した。この ChatBot に対して テキスト だけではなく 音声 で会話ができるように拡張する。

ところで、ChatBotWebブラウザで動作するサンプルアプリケーション が音声入出力をサポートしたい場合に、Webブラウザは ChatBotサーバーとの接続にHTTPS/WSS(TLS)接続 を要求する。これは、マイクなどのデバイスを安全に利用するためのセキュリティ要件になっている。

Webブラウザは、マイクを利用するWebアプリに対し、以下の条件を求める。

  • HTTPS(TLS)接続で配信されていること
  • 信頼できる認証機関(CA)発行の証明書を使用していること(自己署名証明書は不可)

これを満たさない場合、ブラウザはマイクの利用を許可しない

そこで、今回は ChatBot サーバー を ALB(Application Load Balancer)を使って WebSocket の TLS(WSS)に対応させる。

2. ALB を使って TLS をサポートする理由

ALB を使うことで、TLS 証明書の管理が容易になり、負荷分散やスケーリングが簡単になる。AWS Certificate Manager(ACM)を利用すれば、証明書の取得や更新が自動化され、運用負担を大幅に軽減できる。

また、ALB は複数の ECS タスクにリクエストを分散できるため、負荷分散が自動で行われ、トラフィックの急増にも対応しやすくなる。スケールアウト時も ALB が新規タスクに自動でルーティングするため、手動で設定を変更する必要がない。

一方、ECS 内で TLS を処理する場合、各コンテナで個別に証明書を管理する必要があり、手動更新や設定変更の手間が増えます。スケール時には新たにデプロイされるタスクごとに証明書を適用する必要があり、管理が煩雑になりがちです。特に大規模環境では、証明書管理の負担とスケーリングの課題から ALB の利用したほうがよい。

3. システム構成

  • クライアントから WebSocket/TLS(WSS)で ALB に接続
  • ALB から WebSocket (WS) で ECS に接続
  • ECS から WebSocket/TLS (WSS) で OpenAI に接続

image.png

4. 必要な AWS リソース

サービス・機能 役割・説明
Amazon ECS(Fargate) ChatBot を動作させる
Application Load Balancer(ALB) WebSocket(WSS)経由の通信を処理
AWS Certificate Manager(ACM) TLS(SSL)証明書を取得し ALB に適用
Amazon Route 53 カスタムドメインで WebSocket にアクセスする場合に必要

5. ChatBot を ALB で TLS (WSS) に対応させる

前回の記事の 4. Amazon ECSで ChatBot の Docker を起動する(2) タスク定義を作成 まで作業を進めたあと、次のようなステップで TLS (WSS) に対応する。

  1. Amazon Route 53 でドメインを取得 (有料)
  2. AWS Certificate Manager(ACM)で証明書を発行(無料)
  3. Application Load Balancer(ALB)に証明書を適用
  4. ALB に Route 53 で取得したドメインを設定する

(1) Route 53 でドメインを取得

Route 53 のコンソール でドメインを取得する。Route 53 でのドメインの取得方法は下記の記事を参考に実施すれば良い。

(2) AWS Certificate Manager (ACM) で証明書を作成する

ACM のコンソール で証明書をリクエストする。証明書の発行はこちらのサイトの通り行えば良い。AWS Certificate Manager (ACM) を通じてプロビジョニングされたパブリック SSL/TLS 証明書は無料だ。

(3) ALB に TLS(WSS)対応を設定

Amazon ECS のコンソールでクラスタにサービスを作成する

  1. [クラスター] のページで [作成したクラスタ名] を選択する
  2. [サービス][作成] を選択する

image.png

[作成] のページが開く

image.png

  1. [デプロイ設定] までスクロール
  2. [ファミリー][リビジョン] であらかじめ作成しておいたタスクを設定する
  3. [サービス名] を設定する (任意の名称)

image.png

  1. [ロードバランシング] までスクロール
  2. [ロードバランサー名] を設定する (任意の名称)
  3. [リスナー][ポート] に 443 を設定する
  4. [リスナー][プロトコル] に HTTPS を設定する
  5. [リスナー][証明書]ACM 証明書から選択 を選択し、 ACM で作成しておいた証明書 を選択する
  6. 一番下までスクロールして [作成] ボタンを選択肢サービスを作成する

image.png

image.png

(4) ALB に Route 53 で取得したドメインを設定する

サービスを作成すると、ALBには独自のDNS名が設定される。例えば、先ほど作成したALBのDNS名を確認するには次のコマンドを実行する

aws elbv2 describe-load-balancers --names "<your_alb_name>" --query 'LoadBalancers[0].DNSName' --output text
出力例
xxxxx-xxxxxxxx-xxxx-xxx-xxxxxxxxxx.us-east-1.elb.amazonaws.com

このままの状態では、証明書に設定されたドメイン名とALBのDNS名が異なるため、エラーが発生する。

wscat -c xxxxx-xxxxxxxx-xxxx-xxx-xxxxxxxxxx.us-east-1.elb.amazonaws.com
エラー例
error: Hostname/IP does not match certificate's altnames: Host: xxxxx-xxxxxxxx-xxxx-xxx-xxxxxxxxxx.us-east-1.elb.amazonaws.com. is not in the cert's altnames: DNS:xxx-xxxxxx-xxxxxxxxxx.com, DNS:*.xxx-xxxxxx-xxxxxxxxxx.com

この問題を解決するため、Route 53 を使用して独自ドメインをALBに割り当てる。

  1. Route 53 のコンソール を開く
  2. [レコード作成] ボタンを選択する

image.png

  1. [レコードを作成] ページに移動する
  2. [レコード名] を設定する (任意の名称)
  3. [エイリアス] を Enable にする
  4. [トラフィックのルーティング先] に ALB と ALBを作成したリージョン を設定する
  5. [ロードバランサー] を設定する
  6. [レコードを作成] を選択する

この手順で設定した レコード名 がDNSに登録され、そのドメイン名を使ってALBにアクセスできるようになります。

5. クライアントから WSS で接続して動作確認

wscat で動作確認

テキストで ChatBot と会話できることを確かめた

wscat  -c wss://<your_chatbot_domain_name>/ws
出力例
Connected (press CTRL+C to quit)
> Hi ChatGPT
< Hello! How can I assist you today?
> What is AWS?
< AWS, or Amazon Web Services, is a comprehensive cloud computing platform provided by Amazon. It offers a range of services including computing power, storage, databases, machine learning, analytics, and more, enabling businesses to deploy and manage applications and infrastructure in the cloud.

Webブラウザ で動作確認

音声で ChatBot と会話できることを確かめた

Webブラウザで https://<your_chatbot_domain_name> に接続すると下記のUIが表示される。
[Start Audio] を選択すると、音声で ChatBot と会話ができる

image.png

参考サイト

2
0
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
2
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?