Notitie
Voor toegang tot deze pagina is autorisatie vereist. U kunt proberen u aan te melden of mappen te wijzigen.
Voor toegang tot deze pagina is autorisatie vereist. U kunt proberen om mappen te wijzigen.
Maak, test en implementeer hosted Foundry Agent-werkstromen met behulp van de Microsoft Foundry voor Visual Studio Code-extensie. Met gehoste werkstromen kunnen meerdere agents op volgorde samenwerken, elk met een eigen model, hulpprogramma's en instructies.
Voordat u begint, maakt u een agent in Foundry Agent Service met behulp van de extensie. Vervolgens kunt u gehoste werkstromen toevoegen aan die agent.
In dit artikel wordt beschreven hoe u een werkstroom maakt project, deze lokaal uitvoert, de uitvoering visualiseert en implementeert in uw Foundry-werkruimte.
Vereiste voorwaarden
- Een Foundry-project met een geïmplementeerd model of een Azure OpenAI-resource.
- De Microsoft Foundry voor Visual Studio Code-extensie geïnstalleerd.
- De beheerde identiteit van het project met de rollen Azure AI User en AcrPull toegewezen. Wijs ook de rol
acrPulltoe aan de beheerde identiteit van de Foundry-project waar u de gehoste agent wilt implementeren. - Een ondersteunde regio voor gehoste agents.
- Python 3.10 of hoger.
- .NET 9 SDK of hoger.
Een gehoste agentwerkstroom maken
U kunt de Foundry voor Visual Studio Code-extensie gebruiken om gehoste agentwerkstromen te maken. Een gehoste agentwerkstroom is een reeks agents die samenwerken om een taak uit te voeren. Elke agent in de werkstroom kan een eigen model, hulpprogramma's en instructies hebben.
Open het opdrachtenpalet (Ctrl+Shift+P).
Voer deze opdracht uit:
>Microsoft Foundry: Create a New Hosted Agent.Selecteer een programmeertaal.
Selecteer een map waarin u de nieuwe werkstroom wilt opslaan.
Voer een naam in voor uw werkstroom project.
Er wordt een nieuwe map gemaakt met de benodigde bestanden voor de gehoste agent project, inclusief een voorbeeldcodebestand om u op weg te helpen.
Afhankelijkheden installeren
Installeer de vereiste afhankelijkheden voor het project van de gehoste agent. De afhankelijkheden variëren afhankelijk van de programmeertaal die u hebt geselecteerd toen u de project maakte.
Maak een virtuele omgeving.
python -m venv .venvActiveer de virtuele omgeving.
# PowerShell ./.venv/Scripts/Activate.ps1 # Windows cmd .venv\Scripts\activate.bat # Unix/MacOS source .venv/bin/activateInstalleer het volgende pakket:
pip install azure-ai-agentserver-agentframework
Ga naar uw project map en voer deze opdracht uit om de benodigde NuGet-pakketten op te halen:
dotnet restore
Uw gehoste werkstroom lokaal uitvoeren
De voorbeeldwerkstroom project maakt een .env-bestand met de benodigde omgevingsvariabelen. Maak of werk het .env-bestand bij met uw Foundry-referenties:
AZURE_AI_PROJECT_ENDPOINT=https://<your-resource-name>.services.ai.azure.com/api/projects/<your-project-name>
AZURE_AI_MODEL_DEPLOYMENT_NAME=<your-model-deployment-name>
Belangrijk
Voer het .env bestand nooit door naar versiebeheer. Voeg het toe aan uw .gitignore bestand.
Uw gehoste agent authentiseren
Het voorbeeld van de gehoste agent wordt geverifieerd met behulp van DefaultAzureCredential. Configureer uw ontwikkelomgeving om referenties op te geven via een van de ondersteunde bronnen, bijvoorbeeld:
- Azure CLI (
az login) - Aanmelden bij het Visual Studio Code-account
- aanmelding bij Visual Studio account
- Omgevingsvariabelen voor een service-principal (AZURE_TENANT_ID, AZURE_CLIENT_ID, AZURE_CLIENT_SECRET)
Bevestig de verificatie lokaal door de opdrachten Azure CLI az account show of az account get-access-token uit te voeren voordat u het voorbeeld uitvoert.
U kunt de gehoste agent uitvoeren in de interactieve modus of containermodus.
Uw gehoste agent uitvoeren in de interactieve modus
Druk op F5 in VS Code om foutopsporing te starten. U kunt ook het menu voor foutopsporing in VS Code gebruiken:
- Open de weergave Uitvoeren en foutopsporing (Ctrl+Shift+D/Cmd+Shift+D)
- Selecteer 'Debug Local Workflow HTTP Server' in de vervolgkeuzelijst
- Selecteer de groene knop Foutopsporing starten (of druk op F5)
Dit doet het volgende:
- De HTTP-server starten waarvoor foutopsporing is ingeschakeld
- Open de AI Toolkit Agent Inspector voor interactieve tests
- Hiermee kunt u onderbrekingspunten instellen en de uitvoering van de werkstroom in realtime inspecteren.
Uw gehoste agent uitvoeren in de containermodus
Aanbeveling
Open de lokale speeltuin voordat u de containeragent start om ervoor te zorgen dat de visualisatie correct werkt.
De gehoste agent uitvoeren in de containermodus:
- Open het opdrachtpalet Visual Studio Code en voer de opdracht
Microsoft Foundry: Open Container Agent Playground Locallyuit. - Voer deze opdracht uit
main.pyom de gehoste containeragent te initialiseren. - Dien een aanvraag in bij de agent via de speeltuininterface. Voer bijvoorbeeld een prompt in zoals: "Creëer een slogan voor een nieuwe elektrische SUV die betaalbaar en leuk is om te rijden."
- Bekijk het antwoord van de agent in de speeltuininterface.
De voorbeeldwerkstroom project maakt een .env-bestand met de benodigde omgevingsvariabelen. Maak of werk het .env-bestand bij met uw Foundry-referenties:
Stel uw omgevingsvariabelen in op basis van uw besturingssysteem:
$env:AZURE_AI_PROJECT_ENDPOINT="https://<your-resource-name>.services.ai.azure.com/api/projects/<your-project-name>" $env:AZURE_AI_MODEL_DEPLOYMENT_NAME="your-deployment-name"
Uw gehoste agent authentiseren
Het voorbeeld van de gehoste agent wordt geverifieerd met behulp van DefaultAzureCredential. Configureer uw ontwikkelomgeving om referenties op te geven via een van de ondersteunde bronnen, bijvoorbeeld:
- Azure CLI (
az login) - Aanmelding bij een Visual Studio Code-account
- aanmelding bij Visual Studio account
- Omgevingsvariabelen voor een service-principal (AZURE_TENANT_ID, AZURE_CLIENT_ID, AZURE_CLIENT_SECRET)
Bevestig de verificatie lokaal door de opdrachten Azure CLI az account show of az account get-access-token uit te voeren voordat u het voorbeeld uitvoert.
U kunt de gehoste agent uitvoeren in de interactieve modus of containermodus.
Uw gehoste agent uitvoeren in de interactieve modus
Voer de gehoste agent rechtstreeks uit voor ontwikkeling en testen:
dotnet restore
dotnet build
dotnet run
Uw gehoste agent uitvoeren in de containermodus
Aanbeveling
Open de lokale speeltuin voordat u de containeragent start om ervoor te zorgen dat de visualisatie correct werkt.
Om de agent in de containermodus uit te voeren:
- Open het opdrachtpalet Visual Studio Code en voer de opdracht
Microsoft Foundry: Open Container Agent Playground Locallyuit. - Gebruik de volgende opdracht om de gehoste containeragent te initialiseren.
dotnet restore dotnet build dotnet run - Dien een aanvraag in bij de agent via de speeltuininterface. Voer bijvoorbeeld een prompt in zoals: "Creëer een slogan voor een nieuwe elektrische SUV die betaalbaar en leuk is om te rijden."
- Bekijk het antwoord van de agent in de speeltuininterface.
Uitvoering van gehoste agentwerkstroom visualiseren
De Foundry voor Visual Studio Code-extensie biedt een realtime uitvoeringsgrafiek die laat zien hoe agents in uw werkstroom communiceren en samenwerken. Schakel waarneembaarheid in uw project in om deze visualisatie te gebruiken.
Schakel visualisatie in uw werkstromen in door het volgende codefragment toe te voegen:
from agent_framework.observability import setup_observability
setup_observability(vs_code_extension_port=4319) # Default port is 4319
Voeg de volgende verwijzing toe aan uw csproj-bestand:
<ItemGroup>
<PackageReference Include="OpenTelemetry" Version="1.12.0" />
<PackageReference Include="OpenTelemetry.Exporter.Console" Version="1.12.0" />
<PackageReference Include="OpenTelemetry.Exporter.OpenTelemetryProtocol" Version="1.12.0" />
<PackageReference Include="System.Diagnostics.DiagnosticSource" Version="9.0.10" />
</ItemGroup>
Werk uw programma bij om het volgende codefragment op te nemen:
using System.Diagnostics;
using OpenTelemetry;
using OpenTelemetry.Logs;
using OpenTelemetry.Metrics;
using OpenTelemetry.Resources;
using OpenTelemetry.Trace;
var otlpEndpoint =
Environment.GetEnvironmentVariable("OTLP_ENDPOINT") ?? "http://localhost:4319";
var resourceBuilder = OpenTelemetry
.Resources.ResourceBuilder.CreateDefault()
.AddService("WorkflowSample");
var s_tracerProvider = OpenTelemetry
.Sdk.CreateTracerProviderBuilder()
.SetResourceBuilder(resourceBuilder)
.AddSource("Microsoft.Agents.AI.*") // All agent framework sources
.SetSampler(new AlwaysOnSampler()) // Ensure all traces are sampled
.AddOtlpExporter(options =>
{
options.Endpoint = new Uri(otlpEndpoint);
options.Protocol = OpenTelemetry.Exporter.OtlpExportProtocol.Grpc;
})
.Build();
Uw gehoste agentwerkstroom bewaken en visualiseren
De uitvoering van uw gehoste agentwerkstroom in realtime bewaken en visualiseren:
Open het opdrachtenpalet (Ctrl+Shift+P).
Voer deze opdracht uit:
>Microsoft Foundry: Open Visualizer for Hosted Agents.
Er wordt een nieuw tabblad geopend in VS Code om de uitvoeringsgrafiek weer te geven. De visualisatie wordt automatisch bijgewerkt naarmate uw werkstroom vordert, om de stroom tussen agents en hun interacties weer te geven.
Poortconflicten
Voor poortconflicten kunt u de visualisatiepoort wijzigen door deze in te stellen in de instellingen van de Foundry-extensie. Volg deze stappen:
- Selecteer in de linkerzijbalk van VS Code het tandwielpictogram om het instellingenmenu te openen.
- Selecteer
Extensions>Microsoft Foundry Configuration. - Zoek de
Hosted Agent Visualization Portinstelling en wijzig deze in een beschikbaar poortnummer. - Start VS Code opnieuw om de wijzigingen toe te passen.
Poort in code wijzigen
Wijzig de visualisatiepoort door de FOUNDRY_OTLP_PORT omgevingsvariabele in te stellen. Werk de poort voor waarneembaarheid in het workflow.py bestand dienovereenkomstig bij.
Als u bijvoorbeeld de poort wilt wijzigen in 4318, gebruikt u deze opdracht:
export FOUNDRY_OTLP_PORT=4318
Werk in workflow.py de configuratie voor observatie het poortnummer bij:
setup_observability(vs_code_extension_port=4318)
Aanbeveling
Als u meer informatie over foutopsporing wilt inschakelen, voegt u de enable_sensitive_data=True parameter toe aan de setup_observability functie.
Voor poortconflicten wijzigt u de visualisatiepoort door de FOUNDRY_OTLP_PORT omgevingsvariabele in te stellen. Werk het OTLP-eindpunt in uw programma dienovereenkomstig bij.
Als u bijvoorbeeld de poort wilt wijzigen in 4318, gebruikt u deze opdracht:
$env:FOUNDRY_OTLP_PORT="4318"
Werk in uw programma het OTLP-eindpunt bij om het nieuwe poortnummer te gebruiken:
var otlpEndpoint =
Environment.GetEnvironmentVariable("OTLP_ENDPOINT") ?? "http://localhost:4318";
De gehoste agent implementeren
Nadat u de gehoste agent lokaal hebt getest, implementeert u deze in uw Foundry-werkruimte, zodat andere teamleden en toepassingen deze kunnen gebruiken.
Belangrijk
Zorg ervoor dat u de benodigde machtigingen verleent voor het implementeren van gehoste agents in uw Foundry-werkruimte, zoals vermeld in de vereisten. Mogelijk moet u samenwerken met uw Azure-beheerder om de vereiste roltoewijzingen op te halen.
- Open het opdrachtpalet Visual Studio Code en voer de opdracht
Microsoft Foundry: Deploy Hosted Agentuit. - Configureer de implementatie-instellingen door uw doelwerkruimte te selecteren, het containeragentbestand (
container.py) op te geven en indien nodig andere implementatieparameters te definiëren. - Na een geslaagde implementatie verschijnt de gehoste agent in de
Hosted Agents (Preview)-sectie van de boomstructuurweergave van de Microsoft Foundry-extensie. - Selecteer de geïmplementeerde agent om toegang te krijgen tot gedetailleerde informatie en de testfunctionaliteit met behulp van de geïntegreerde sandbox-omgeving.
- Open het opdrachtpalet Visual Studio Code en voer de opdracht
Microsoft Foundry: Deploy Hosted Agentuit. - Configureer de implementatie-instellingen door uw doelwerkruimte te selecteren, het containeragentbestand (
<your-project-name>.csproj) op te geven en indien nodig andere implementatieparameters te definiëren. - Na een geslaagde implementatie verschijnt de gehoste agent in de
Hosted Agents (Preview)-sectie van de boomstructuurweergave van de Microsoft Foundry-extensie. - Selecteer de geïmplementeerde agent om gedetailleerde informatie en testfunctionaliteit te verkrijgen met behulp van de geïntegreerde testomgeving.