このチュートリアルでは、既存のデータ ドリブン ASP.NET Core CRUD アプリケーションにエージェント機能を追加する方法について説明します。 これは、Microsoft Agent Framework と Foundry Agent Service という 2 つの異なる方法を使用して行われます。
Web アプリケーションにショッピング、ホテル予約、データ管理などの便利な機能が既にある場合は、これらの機能をツール ( Microsoft Agent Framework 用) または OpenAPI エンドポイント ( Foundry Agent Service 用) としてラップすることで、Web アプリケーションにエージェント機能を追加するのは比較的簡単です。 このチュートリアルでは、簡単な to-do リスト アプリから始めます。 最終的には、App Service アプリでエージェントを使用してタスクを作成、更新、管理できるようになります。
Microsoft Agent Framework と Foundry Agent Service の両方を使用すると、AI 主導の機能を備えたエージェント Web アプリケーションを構築できます。 次の表に、いくつかの考慮事項とトレードオフを示します。
| Consideration | Microsoft Agent Framework | ファウンドリー エージェント サービス |
|---|---|---|
| Performance | 高速 (ローカルで実行) | 低速 (マネージド、リモート サービス) |
| Development | 完全なコード、最大制御 | 低いコード、迅速な統合 |
| Testing | コードでの手動/単体テスト | クイック テスト用の組み込みプレイグラウンド |
| Scalability | アプリで管理 | Azure マネージド、自動スケーリング |
| セキュリティ ガードレール | カスタム実装が必要 | 組み込みのコンテンツの安全性とモデレーション |
| アイデンティティ | カスタム実装が必要 | 組み込みのエージェント ID と認証 |
| Enterprise | カスタム統合が必要 | 組み込みの Microsoft 365/Teams 展開と Microsoft 365 統合ツール呼び出し。 |
このチュートリアルでは、以下の内容を学習します。
- 既存のアプリ機能を Microsoft Agent Framework のツールに変換します。
- ツールを Microsoft Agent Framework エージェントに追加し、Web アプリで使用します。
- 既存のアプリ機能を Foundry Agent Service の OpenAPI エンドポイントに変換します。
- Web アプリで Foundry エージェントを呼び出します。
- マネージド ID 接続に必要なアクセス許可を割り当てます。
Prerequisites
- アクティブなサブスクリプションを持つ Azure アカウント - アカウントを無料で作成します。
- GitHub Codespaces を使用するための GitHub アカウント - GitHub Codespaces の詳細を確認します。
Codespaces を使用してサンプルを開く
開始する最も簡単な方法は、GitHub Codespaces を使用することです。GitHub Codespaces を使用すると、必要なすべてのツールがプレインストールされた完全な開発環境が提供されます。
https://github.com/Azure-Samples/app-service-agentic-semantic-kernel-ai-foundry-agentにある GitHub リポジトリに移動します。
[ コード ] ボタンを選択し、[ Codespaces ] タブを選択し、[ メインでコードスペースを作成] を選択します。
Codespace が初期化されるまでしばらく待ちます。 準備ができたら、ブラウザーに完全に構成された開発環境が表示されます。
アプリケーションをローカルで実行します。
dotnet runポート 5280 で実行されているアプリケーションが表示されたら、[ブラウザーで開く] を選択し、いくつかのタスクを追加します。
エージェント コードを確認する
どちらの方法でも同じ実装パターンが使用されます。この場合、エージェントはプロバイダーのサービス (Program.cs) として初期化され、それぞれの Blazor コンポーネントに挿入されます。
AgentFrameworkProviderは Services/AgentFrameworkProvider.cs で初期化されます。 初期化コードでは、次の処理が行われます。
- Azure OpenAI から
IChatClientを使用してAzureOpenAIClientを作成します。 - CRUD アプリケーションの機能をカプセル化する
TaskCrudToolインスタンスを取得します ( Tools/TaskCrudTool.cs)。 ツール メソッドのDescription属性は、エージェントがそれらを呼び出す方法を決定するのに役立ちます。 -
CreateAIAgent()によって登録された手順とツールを使用して、AIFunctionFactory.Create()を使用して AI エージェントを作成します。 - エージェントがナビゲーション全体で会話を保持するためのスレッドを作成します。
// Create IChatClient
IChatClient chatClient = new AzureOpenAIClient(
new Uri(endpoint),
new DefaultAzureCredential())
.GetChatClient(deployment)
.AsIChatClient();
// Get TaskCrudTool instance from service provider
var taskCrudTool = sp.GetRequiredService<TaskCrudTool>();
// Create agent with tools
var agent = chatClient.CreateAIAgent(
instructions: @"You are an agent that manages tasks using CRUD operations.
Use the provided functions to create, read, update, and delete tasks.
Always call the appropriate function for any task management request.
Don't try to handle any requests that are not related to task management.
When handling requests, if you're missing any information, don't make it up but prompt the user for it instead.",
tools:
[
AIFunctionFactory.Create(taskCrudTool.CreateTaskAsync),
AIFunctionFactory.Create(taskCrudTool.ReadTasksAsync),
AIFunctionFactory.Create(taskCrudTool.UpdateTaskAsync),
AIFunctionFactory.Create(taskCrudTool.DeleteTaskAsync)
]);
// Create thread for this scoped instance (persists across navigation)
var thread = agent.GetNewThread();
return (agent, thread);
ユーザーがメッセージを送信するたびに、Blazor コンポーネント ( Components/Pages/AgentFrameworkAgent.razor) は、ユーザー入力とエージェント スレッドで Agent.RunAsync() を呼び出します。 エージェント スレッドはチャット履歴を追跡します。
var response = await this.Agent.RunAsync(sentInput, this.agentThread);
サンプル アプリケーションをデプロイする
サンプル リポジトリには、マネージド ID を使用して App Service アプリを作成し、サンプル アプリケーションをデプロイする Azure Developer CLI (AZD) テンプレートが含まれています。
ターミナルで、Azure Developer CLI を使用して Azure にログインします。
azd auth login手順に従って認証プロセスを完了します。
AZD テンプレートを使用して Azure App Service アプリをデプロイします。
azd upメッセージが表示されたら、次の回答を入力します。
Question Answer 新しい環境名を入力します。 一意の名前を入力します。 使用する Azure サブスクリプションを選択します。 サブスクリプションを選択します。 使用するリソース グループを選択します。 [Create a new resource group]\(新しいリソース グループの作成\) を選択します。 リソース グループを作成する場所を選択します。 [スウェーデン中部] を選択します。 新しいリソース グループの名前を入力します。 「Enter」と入力します。 AZD の出力で、アプリの URL を見つけ、ブラウザーでそこに移動します。 URL は、AZD の出力では次のようになります。
Deploying services (azd deploy) (✓) Done: Deploying service web - Endpoint: <URL>
OpenAPI スキーマ項目を選択して、自動生成された OpenAPI スキーマを既定の
/openapi/v1.jsonパスで開きます。 このスキーマは後で必要になります。デプロイが成功すると、デプロイされたアプリケーションの URL が表示されます。
これで、システム割り当てマネージド ID を持つ App Service アプリが作成されました。
Microsoft Foundry リソースを作成して構成する
Foundry ポータルで、上部の [New Foundry] ラジオ ボタンがアクティブに設定されていることを確認し、プロジェクトを作成します。
任意のモデルをデプロイします ( Microsoft Foundry クイック スタート: リソースの作成を参照)。
モデルプレイグラウンドの上部から、モデル名をコピーします。
Azure OpenAI エンドポイントを取得する最も簡単な方法は、まだクラシック ポータルから行う方法です。 New Foundry ラジオ ボタン、Azure OpenAI の順に選択し、後で使用するために Azure OpenAI エンドポイント の URL をコピーします。
必要なアクセス許可を割り当てる
新しい Foundry ポータルの上部メニューから [ 操作] を選択し、[ 管理者] を選択します。Foundry プロジェクトの行には、2 つのリンクが表示されます。 [名前] 列の 1 つは Foundry プロジェクト リソースで、[親リソース] 列のリソースは Foundry リソースです。
親リソースで Foundry リソース を選択し、 Azure portal で [このリソースの管理] を選択します。 Azure portal から、デプロイされた Web アプリにリソースのロールベースのアクセス権を割り当てることができます。
App Service アプリのマネージド ID に次のロールを追加します。
ターゲット リソース 必要なロール 次の場合に必要です 鋳造所 Cognitive Services OpenAI ユーザー Microsoft Agent Framework のチャット完了サービス。 手順については、「Azure portal を使用して Azure ロールを割り当てる」を参照してください。
サンプル アプリケーションで接続変数を構成する
appsettings.json を開きます。 Foundry ポータルから前にコピーした値を使用して、次の変数を構成します。
Variable Description AzureOpenAIEndpointAzure OpenAI エンドポイント (クラシック Foundry ポータルからコピー)。 ModelDeploymentデプロイのモデル名(新しい Foundry ポータルのモデルプレイグラウンドからコピー)。 Note
チュートリアルをシンプルにするために、App Service のアプリ設定で上書きするのではなく、appsettings.json でこれらの変数を使用します。
Note
チュートリアルをシンプルにするために、App Service のアプリ設定で上書きするのではなく、appsettings.json でこれらの変数を使用します。
Azure CLI を使用して Azure にサインインします。
az loginこれにより、サンプル コード内の Azure ID クライアント ライブラリは、ログインしているユーザーの認証トークンを受け取ることができます。 前にこのユーザーに必要なロールを追加したことを思い出してください。
アプリケーションをローカルで実行します。
dotnet runポート 5280 で実行されているアプリケーションが表示されたら、[ブラウザーで開く] を選択します。
Microsoft Agent Framework エージェント のリンクと Foundry Agent Service のリンクを選択して、チャット インターフェイスを試します。 応答が返された場合、アプリケーションは Microsoft Foundry リソースに正常に接続されています。
GitHub コードスペースに戻り、アプリの変更をデプロイします。
azd upデプロイされたアプリケーションにもう一度移動し、チャット エージェントをテストします。
リソースをクリーンアップする
アプリケーションの使用が完了したら、App Service リソースを削除して、追加のコストが発生しないようにすることができます。
azd down --purge
AZD テンプレートには Microsoft Foundry リソースが含まれていないため、必要に応じて手動で削除する必要があります。