Azure SignalR Service を利用して,ブラウザ上でチャットのサンプルを動作させます.
SignalR 概要
- https://docs.microsoft.com/ja-jp/aspnet/core/signalr/introduction?view=aspnetcore-5.0
- ブラウザなどからリアルタイム通信を行うためのライブラリ
- 内部的にはWebSocketやポーリングなどを利用して双方向での通信を実現している
- 利用者は内部の通信処理を意識することなくブラウザにリアルタイム通信機能を追加できる
- 自前実装には別途サーバー側の実装も必要
Azure SignalR Service 概要
- https://azure.microsoft.com/ja-jp/services/signalr-service/#overview
- ブラウザでのリアルタイム通信を実現するためのサーバー側機能を構築してくれる
- Azure Function と組み合わせることでブラウザからの SignalR サーバーへの接続とリアルタイム通信を追加可能
チャットアプリのサンプル実行
- 利用した Function サンプルプロジェクト
- https://docs.microsoft.com/ja-jp/azure/azure-signalr/signalr-quickstart-azure-functions-csharp
Azure SignalR Service 設定
Azure ポータルから
SignalR Service
を作成Service mode
をServerless
にして作成作成後
Keys
のConnection string
を控えておく
Azure Function 設定
- Azure ポータルから
Function App
を作成
data:image/s3,"s3://crabby-images/d1b3e/d1b3e3a82402afe4e2b9d93a131a74f9ebd5edc8" alt=""
data:image/s3,"s3://crabby-images/fdc6d/fdc6d11b24693de8aec3067ac4283fbda6419783" alt=""
Function 作成
開発環境
- https://docs.microsoft.com/ja-jp/azure/azure-signalr/signalr-quickstart-azure-functions-csharp
上記のプロジェクトをCloneして, C# 用の Function プロジェクト
signalr-service-quickstart-serverless-chat\src\chat\csharp\FunctionApp.sln
を Visual Studio で開くAzure 環境にアップロードするため,パッケージのバージョンを更新
プロジェクトを右クリックから
Manage NuGet Packages...
を開き以下を設定Microsoft.NET.Sdk.Function
を3.0.13
に更新Microsoft.Azure.WebJobs.Extensions.SignalRService
を1.3.0
に更新Microsoft.Azure.WebJobs.Extensions
の4.0.1
を追加Microsoft.Azure.WebJobs.Extensions.Http
の3.0.12
を追加
data:image/s3,"s3://crabby-images/1a89d/1a89dedf1fdb9f708f5ec4cd8e38b5caf6cc7221" alt=""
data:image/s3,"s3://crabby-images/dc6a5/dc6a5b85e9856141efc5b657baf1a7325ef6e666" alt=""
data:image/s3,"s3://crabby-images/9cb41/9cb41713b95d7a6c81cad6a484ba5c7eecfdcb82" alt=""
Function.cs
内では SignalR 接続処理を行うnegotiate
と送受信データを処理するmessages
が実装されています
サンプルプロジェクトのローカル実行
local.settings.sample.json
をlocal.settings.json
に名前変更local.settings.json
のAzureSignalRConnectionString
に Azure SignalR Service 作成時に控えておいたConnection string
を入力
data:image/s3,"s3://crabby-images/ff14d/ff14d15c74f068b0dee6151f1dbf5093cde119c5" alt=""
- プロジェクト実行後,以下のブラウザにアクセスしチャット機能を確認
- https://azure-samples.github.io/signalr-service-quickstart-serverless-chat/demo/chat-v2/
- Azure Function 接続URLの指定は,ローカル実行時にはデフォルト(
http://localhost:7071
)を利用
data:image/s3,"s3://crabby-images/32e5a/32e5ae575978a248afb33a524a3adf116b747e09" alt=""
- 複数のブラウザでアクセスすることでチャット機能を確認できる
data:image/s3,"s3://crabby-images/8cc51/8cc511e0de9064663986b64550debad6079aed0a" alt=""
サンプルプロジェクトの Azure 実行
- 作成した Function プロジェクトを Azure にアップロード
- プロジェクト右クリックから
Publish
を選択
data:image/s3,"s3://crabby-images/1252b/1252b34446c920f1d7dd98c2f127add493c3415b" alt=""
- アップロード先に Azure を選択し,アップロードする Azure Function を選択
data:image/s3,"s3://crabby-images/0f783/0f783bd4a027acafb3bb46d8acb8cc413d07a9b8" alt=""
data:image/s3,"s3://crabby-images/e3e73/e3e73936760e74abc12fe791e058a99df618f623" alt=""
アップロード先の Azure Function を指定できたら,
Publish
からアップロードを行うアップロードに成功すると Azure ポータルの Azure Function の関数画面に
message
とnegotiate
が確認できる
data:image/s3,"s3://crabby-images/ce27f/ce27f15da2b2ecd7c6ce6c02c904135c3034c6fa" alt=""
- 作成した SignalR Service に接続するために Azure Function に接続文字列を設定する
Configuration
のApplication settings
からNew application setting
を行う- Name に
AzureSignalRConnectionString
と Value に SignalR Service 作成時に控えたConnection string
を入力
data:image/s3,"s3://crabby-images/f2dab/f2dab78a9d111756ee93ae2aa01da108c97b27eb" alt=""
data:image/s3,"s3://crabby-images/8585c/8585c0bbc7a38d74101a3f98d65e2a69286bb073" alt=""
- 外部からの接続を許可するために
CORS
のEnable Access-Control-Allow-Credentials
にチェック https://azure-samples.github.io
を設定
data:image/s3,"s3://crabby-images/95fc2/95fc28a6651e13b638404bf0c6372b5b7a31aad6" alt=""
- 以下のブラウザにアクセスしチャット機能を確認
- https://azure-samples.github.io/signalr-service-quickstart-serverless-chat/demo/chat-v2/
- Azure Function 接続URLの指定は,設定した Azure Function の URL を利用
data:image/s3,"s3://crabby-images/7e504/7e504b35be348818ffb70b85eb816e8fccbcc195" alt=""
- 複数のブラウザでアクセスすることでチャット機能を確認できる
まとめ
- まずはブラウザ間でSignalRを利用したチャットアプリが動くことが確認できた.