Nota
L'accesso a questa pagina richiede l'autorizzazione. È possibile provare ad accedere o modificare le directory.
L'accesso a questa pagina richiede l'autorizzazione. È possibile provare a modificare le directory.
Questa esercitazione illustra come aggiungere funzionalità agentiche a un'applicazione CRUD FastAPI basata sui dati esistente. A tale scopo, si usano due approcci diversi: LangGraph e Foundry Agent Service.
Se l'applicazione Web ha già funzionalità utili, ad esempio acquisti, prenotazioni di hotel o gestione dei dati, è relativamente semplice aggiungere funzionalità dell'agente all'applicazione Web eseguendo il wrapping di tali funzionalità in un plug-in (per LangGraph) o come endpoint OpenAPI (per il servizio agente Foundry). In questa esercitazione, si inizia con una semplice app di elenco attività. Al termine, si sarà in grado di creare, aggiornare e gestire attività con un agente in un'app di Servizio app.
Sia LangGraph che il servizio agente Foundry consentono di creare applicazioni Web agentic con funzionalità basate su intelligenza artificiale. LangGraph è simile a Microsoft Agent Framework ed è un SDK. La tabella seguente illustra alcune considerazioni e compromessi:
| Considerazione | LangGraph o Microsoft Agent Framework | Servizio Agente Fonderia |
|---|---|---|
| Performance | Veloce (eseguito localmente) | Più lento (gestito, servizio remoto) |
| Sviluppo | Codice completo, massimo controllo | Poco codice, integrazione rapida |
| Testing | Test manuali/unit test nel codice | Playground predefinito per i test rapidi |
| Scalabilità | Gestito dall'app | Gestito da Azure, con scalabilità automatica |
| Protezioni di sicurezza | Implementazione personalizzata richiesta | Sicurezza e moderazione dei contenuti predefiniti |
| Identità | Implementazione personalizzata richiesta | ID e autenticazione predefiniti dell'agente |
| Enterprise | Integrazione personalizzata richiesta | Distribuzione predefinita di Microsoft 365/Teams e chiamate agli strumenti integrati di Microsoft 365. |
In questa esercitazione si apprenderà come:
- Convertire le funzionalità dell'app esistenti in un plug-in per LangGraph.
- Aggiungere il plug-in a un agente LangGraph e usarlo in un'app Web.
- Convertire le funzionalità dell'app esistenti in un endpoint OpenAPI per il servizio agente Foundry.
- Chiamare un agente Foundry in un'applicazione web.
- Assegnare le autorizzazioni necessarie per la connettività dell'identità gestita.
Prerequisiti
- Un account Azure con un abbonamento attivo - Creare gratuitamente un account.
- Account GitHub per l'uso di GitHub Codespaces - Altre informazioni su GitHub Codespaces.
Aprire l'esempio con Codespaces
Il modo più semplice per iniziare consiste nell'usare GitHub Codespaces, che offre un ambiente di sviluppo completo con tutti gli strumenti necessari preinstallati.
Passare al repository GitHub su https://github.com/Azure-Samples/app-service-agentic-langgraph-foundry-python.
Selezionare il pulsante Codice, selezionare la scheda Codespaces, quindi selezionare Crea codespace in main.
Attendere per alcuni istanti l'inizializzazione di Codespace. Quando si è pronti, nel browser si vedrà un ambiente di sviluppo completamente configurato.
Eseguire l'applicazione in locale:
python3 -m venv venv source venv/bin/activate pip install -r requirements.txt uvicorn src.app:app --host 0.0.0.0 --port 3000Quando viene visualizzato L'applicazione in esecuzione sulla porta 3000 è disponibile, selezionare Apri nel browser e aggiungere alcune attività.
Gli agenti non sono completamente configurati, per cui non funzionano ancora. Verranno configurati in un secondo momento.
Esaminare il codice dell'agente
Entrambi gli approcci usano lo stesso modello di implementazione, in cui l'agente viene inizializzato all'avvio dell'applicazione e risponde ai messaggi dell'utente tramite richieste POST.
LangGraphTaskAgent viene inizializzato nel costruttore in src/agents/langgraph_task_agent.py. Il codice di inizializzazione effettua le operazioni seguenti:
- Configura il client AzureChatOpenAI usando variabili di ambiente.
- Crea l'agente ReAct predefinito con memoria e un set di strumenti CRUD per la gestione delle attività (vedere Guida introduttiva a LangGraph).
# Initialize Azure OpenAI client
credential = DefaultAzureCredential()
azure_ad_token_provider = get_bearer_token_provider(
credential, "https://cognitiveservices.azure.com/.default"
)
self.llm = AzureChatOpenAI(
azure_endpoint=endpoint,
azure_deployment=deployment_name,
azure_ad_token_provider=azure_ad_token_provider,
api_version="2024-10-21"
)
# Define tools
tools = [
self._create_task_tool(),
self._get_tasks_tool(),
self._get_task_tool(),
self._update_task_tool(),
self._delete_task_tool()
]
# Create the agent
self.agent = create_react_agent(self.llm, tools, checkpointer=self.memory)
print("LangGraph Task Agent initialized successfully")
Durante l'elaborazione dei messaggi utente, l'agente viene richiamato usando ainvoke() con il messaggio dell'utente e un ID thread per la continuità della conversazione:
result = await self.agent.ainvoke(
{"messages": [("user", message)]},
config=config
)
Distribuire l'applicazione di esempio
Il repository di esempio contiene un modello di Azure Developer CLI (AZD) che crea un'app di Servizio app con identità gestita e distribuisce l'applicazione di esempio.
Nel terminale, accedere ad Azure usando Azure Developer CLI:
azd auth loginSeguire le istruzioni per completare il processo di autenticazione.
Distribuire l'app di Servizio app di Azure con il modello AZD:
azd upQuando richiesto, fornire le risposte seguenti:
Domanda Risposta Immettere un nuovo nome ambiente: Digitare un nome univoco. Selezionare un abbonamento di Azure da usare: Selezionare la sottoscrizione. Selezionare un gruppo di risorse da usare: Selezionare Crea un nuovo gruppo di risorse. Selezionare un percorso in cui creare il gruppo di risorse: Selezionare Svezia centrale. Immettere un nome per il nuovo gruppo di risorse: Immettere INVIO. Nell'output AZD, trova l'URL dell'app e accedi ad esso tramite il browser. L'URL è simile al seguente nell'output AZD:
Deploying services (azd deploy) (✓) Done: Deploying service web - Endpoint: <URL>
Aprire lo schema OpenAPI generato automaticamente nel
https://....azurewebsites.net/openapi.jsonpercorso. Questo schema sarà necessario in un secondo momento.Ora è disponibile un'app di Servizio app con un'identità gestita assegnata dal sistema.
Creare e configurare la risorsa Microsoft Foundry
Nel portale di Foundry verificare che il pulsante di opzione New Foundry in alto sia impostato su attivo e creare un progetto.
Distribuire un modello preferito (vedere Avvio rapido di Microsoft Foundry: Creare risorse).
Nella parte superiore del playground del modello copiare il nome del modello.
Il modo più semplice per ottenere l'endpoint OpenAI di Azure è ancora dal portale classico. Selezionare il pulsante di opzione New Foundry, quindi Azure OpenAI, e quindi copiare l'URL nell'Azure OpenAI endpoint per un secondo momento.
Assegnare le autorizzazioni necessarie
Nel menu in alto del nuovo portale Foundry, selezionare Opera, quindi Amministrazione. Nella riga del progetto Foundry, dovrebbero essere visualizzati due collegamenti. Quello nella colonna Nome è la risorsa del progetto Foundry e quella nella colonna Risorsa padre è la risorsa Foundry.
Selezionare la risorsa Foundry nella risorsa padre e quindi selezionare Gestisci questa risorsa nel portale di Azure. Dal portale di Azure è possibile assegnare l'accesso in base al ruolo per la risorsa all'app Web distribuita.
Aggiungi il ruolo seguente per l'identità gestita dell'app di App Service:
Risorsa di destinazione Ruolo obbligatorio Necessario per Fonderia Utente di Servizi Cognitivi OpenAI Servizio di completamento della chat in Microsoft Agent Framework. Per istruzioni, vedere Assegnare ruoli di Azure usando il portale di Azure.
Configurare le variabili di connessione nell'applicazione di esempio
Aprire il file con estensione env. Usando i valori copiati in precedenza dal portale foundry, configurare le variabili seguenti:
Variable Description AZURE_OPENAI_ENDPOINTEndpoint OpenAI di Azure (copiato dal portale di Foundry classico). AZURE_OPENAI_DEPLOYMENT_NAMENome del modello nella distribuzione (copiato dall'area di sperimentazione del modello nel nuovo portale Foundry). Annotazioni
Per semplificare l'esercitazione, queste variabili verranno usate in .env invece di sovrascriverle con le impostazioni dell'app nel servizio app.
Annotazioni
Per semplificare l'esercitazione, queste variabili verranno usate in .env invece di sovrascriverle con le impostazioni dell'app nel servizio app.
Accedere ad Azure con l'interfaccia della riga di comando di Azure:
az loginCiò consente alla libreria client di Identità di Azure nel codice di esempio di ricevere un token di autenticazione per l'utente connesso. Tenere presente che è stato aggiunto il ruolo necessario per questo utente in precedenza.
Eseguire l'applicazione in locale:
npm run build npm startQuando viene visualizzato L'applicazione in esecuzione sulla porta 3000 è disponibile, selezionare Apri nel browser.
Selezionare il collegamento Agente LangGraph e il collegamento Agente Fonderia per provare l'interfaccia di chat. Se si riceve una risposta, l'applicazione si connette correttamente alla risorsa Microsoft Foundry.
Tornare nel codespace di GitHub, distribuire le modifiche dell'app.
azd upPassare di nuovo all'applicazione distribuita e testare gli agenti di chat.
Pulire le risorse
Al termine dell'applicazione, è possibile eliminare le risorse del servizio app per evitare di sostenere ulteriori costi:
azd down --purge
Poiché il modello AZD non include le risorse di Microsoft Foundry, è necessario eliminarle manualmente, se necessario.