Nota
O acesso a esta página requer autorização. Podes tentar iniciar sessão ou mudar de diretório.
O acesso a esta página requer autorização. Podes tentar mudar de diretório.
Este tutorial demonstra como adicionar capacidade de agente a um aplicativo CRUD Express.js orientado por dados existente. Faz isto usando duas abordagens diferentes: LangGraph e Foundry Agent Service.
Se a sua aplicação web já tem funcionalidades úteis, como compras, reservas de hotel ou gestão de dados, é relativamente simples adicionar funcionalidades de agente à sua aplicação web, envolvendo essas funcionalidades num plugin (para LangGraph) ou como endpoint OpenAPI (para Foundry Agent Service). Neste tutorial, começas com uma aplicação de lista simples to-do. No final, você poderá criar, atualizar e gerenciar tarefas com um agente em um aplicativo do Serviço de Aplicativo.
Tanto o LangGraph como o Foundry Agent Service permitem-lhe construir aplicações web agentes com capacidades baseadas em IA. LangGraph é semelhante ao Microsoft Semantic Kernel e é um SDK, mas Semantic Kernel não suporta JavaScript atualmente. A tabela a seguir mostra algumas das considerações e compensações:
| Consideration | LangGraph | Serviço de Agente de Fundição |
|---|---|---|
| Performance | Rápido (funciona localmente) | Mais lento (gerenciado, serviço remoto) |
| Development | Código completo, controlo máximo | Baixo código, integração rápida |
| Testing | Testes manuais/unitários em código | Playground integrado para testes rápidos |
| Scalability | App-managed | Gerenciado pelo Azure, dimensionado automaticamente |
| Guarda-corpos de segurança | Implementação personalizada necessária | Segurança e moderação de conteúdos incorporadas |
| Identidade | Implementação personalizada necessária | ID de agente incorporado e autenticação |
| Enterprise | Integração personalizada necessária | Implementação integrada do Microsoft 365/Teams e chamadas de ferramentas integradas no Microsoft 365. |
Neste tutorial, aprenderás como:
- Converta a funcionalidade existente do aplicativo em um plug-in para o LangGraph.
- Adicione o plug-in a um agente LangGraph e use-o em um aplicativo Web.
- Converter funcionalidades existentes da aplicação num endpoint OpenAPI para o Foundry Agent Service.
- Ligue para um agente da Foundry numa aplicação web.
- Atribua as permissões necessárias para conectividade de identidade gerenciada.
Prerequisites
- Uma conta do Azure com uma subscrição ativa - Crie uma conta gratuitamente.
- Conta do GitHub para usar o GitHub Codespaces - Saiba mais sobre o GitHub Codespaces.
Abra o exemplo com Codespaces
A maneira mais fácil de começar é usando o GitHub Codespaces, que fornece um ambiente de desenvolvimento completo com todas as ferramentas necessárias pré-instaladas.
Navegue até o repositório GitHub em https://github.com/Azure-Samples/app-service-agentic-langgraph-foundry-node.
Selecione o botão Código , selecione a guia Espaços de código e selecione Criar espaço de código na principal.
Aguarde alguns instantes até que o Codespace seja inicializado. Quando estiver pronto, você verá um ambiente de desenvolvimento totalmente configurado em seu navegador.
Execute o aplicativo localmente:
npm install npm run build npm startQuando vir que a sua aplicação em execução na porta 3000 está disponível, selecione Abrir no Browser e adicione algumas tarefas.
Os agentes não estão totalmente configurados, por isso ainda não funcionam. Você os configurará mais tarde.
Revise o código do agente
Ambas as abordagens usam o mesmo padrão de implementação, onde o agente é inicializado no início do aplicativo e responde às mensagens do usuário por solicitações POST.
O LangGraphTaskAgent é inicializado no construtor em src/agents/LangGraphTaskAgent.ts. O código de inicialização faz o seguinte:
- Configura o cliente AzureChatOpenAI usando variáveis de ambiente.
- Cria o agente ReAct pré-construído com um conjunto de ferramentas CRUD para gerenciamento de tarefas (consulte LangGraph: Como usar o agente ReAct pré-construído).
- Configura o gerenciamento de memória (consulte LangGraph: Como adicionar memória ao agente ReAct pré-construído).
constructor(taskService: TaskService) {
this.taskService = taskService;
this.memory = new MemorySaver();
try {
const endpoint = process.env.AZURE_OPENAI_ENDPOINT;
const deploymentName = process.env.AZURE_OPENAI_DEPLOYMENT_NAME;
if (!endpoint || !deploymentName) {
console.warn('Azure OpenAI configuration missing for LangGraph agent');
return;
}
// Initialize Azure OpenAI client
const credential = new DefaultAzureCredential();
const azureADTokenProvider = getBearerTokenProvider(credential, "https://cognitiveservices.azure.com/.default");
this.llm = new AzureChatOpenAI({
azureOpenAIEndpoint: endpoint,
azureOpenAIApiDeploymentName: deploymentName,
azureADTokenProvider: azureADTokenProvider,
azureOpenAIApiVersion: "2024-10-21"
});
// Define tools directly in the array
const tools = [
tool(
async ({ title, isComplete = false }) => {
const task = await this.taskService.addTask(title, isComplete);
return `Task created successfully: "${task.title}" (ID: ${task.id})`;
},
{
name: 'createTask',
description: 'Create a new task',
schema: z.object({
title: z.string(),
isComplete: z.boolean().optional()
}) as any
}
),
tool(
async () => {
const tasks = await this.taskService.getAllTasks();
if (tasks.length === 0) {
return 'No tasks found.';
}
return `Found ${tasks.length} tasks:\n` +
tasks.map(t => `- ${t.id}: ${t.title} (${t.isComplete ? 'Complete' : 'Incomplete'})`).join('\n');
},
{
name: 'getTasks',
description: 'Get all tasks',
schema: z.object({}) as any
}
),
tool(
async ({ id }) => {
const task = await this.taskService.getTaskById(id);
if (!task) {
return `Task with ID ${id} not found.`;
}
return `Task ${task.id}: "${task.title}" - Status: ${task.isComplete ? 'Complete' : 'Incomplete'}`;
},
{
name: 'getTask',
description: 'Get a specific task by ID',
schema: z.object({
id: z.number()
}) as any
}
),
tool(
async ({ id, title, isComplete }) => {
const updated = await this.taskService.updateTask(id, title, isComplete);
if (!updated) {
return `Task with ID ${id} not found.`;
}
return `Task ${id} updated successfully.`;
},
{
name: 'updateTask',
description: 'Update an existing task',
schema: z.object({
id: z.number(),
title: z.string().optional(),
isComplete: z.boolean().optional()
}) as any
}
),
tool(
async ({ id }) => {
const deleted = await this.taskService.deleteTask(id);
if (!deleted) {
return `Task with ID ${id} not found.`;
}
return `Task ${id} deleted successfully.`;
},
{
name: 'deleteTask',
description: 'Delete a task',
schema: z.object({
id: z.number()
}) as any
}
)
];
// Create the ReAct agent with memory
this.agent = createReactAgent({
llm: this.llm,
tools,
checkpointSaver: this.memory,
stateModifier: `You are an AI assistant that manages tasks using CRUD operations.
You have access to tools for creating, reading, updating, and deleting tasks.
Always use the appropriate tool for any task management request.
Be helpful and provide clear responses about the actions you take.
If you need more information to complete a request, ask the user for it.`
});
} catch (error) {
console.error('Error initializing LangGraph agent:', error);
}
}
Ao processar mensagens do utilizador, o agente é invocado usando invoke() com a mensagem do utilizador e a configuração da sessão para a continuidade da conversa.
const result = await this.agent.invoke(
{
messages: [
{ role: 'user', content: message }
]
},
{
configurable: {
thread_id: currentSessionId
}
}
);
Implementar o exemplo de aplicação
O repositório de exemplo contém um modelo de CLI do Desenvolvedor do Azure (AZD), que cria um aplicativo do Serviço de Aplicativo com identidade gerenciada e implanta seu aplicativo de exemplo.
No terminal, faça logon no Azure usando a CLI do Azure Developer:
azd auth loginSiga as instruções para concluir o processo de autenticação.
Implante o aplicativo do Serviço de Aplicativo do Azure com o modelo AZD:
azd upQuando solicitado, forneça as seguintes respostas:
Question Answer Insira um novo nome de ambiente: Escreva um nome exclusivo. Selecione uma Assinatura do Azure para usar: Selecione uma subscrição. Escolha um grupo de recursos para usar: Selecione Criar um novo grupo de recursos. Selecione um local para criar o grupo de recursos em: Selecione Suécia Central. Insira um nome para o novo grupo de recursos: Digite Enter. Na saída AZD, localize a URL do seu aplicativo e navegue até ela no navegador. O URL tem esta aparência na saída AZD:
Deploying services (azd deploy) (✓) Done: Deploying service web - Endpoint: <URL>
Abra o esquema OpenAPI gerado automaticamente no
https://....azurewebsites.net/api/schemacaminho. Você precisará desse esquema mais tarde.Agora você tem um aplicativo do Serviço de Aplicativo com uma identidade gerenciada atribuída ao sistema.
Crie e configure o recurso Microsoft Foundry
No portal da Foundry, certifique-se de que o botão de radio superior da New Foundry está ativado e crie um projeto.
Implemente um modelo à sua escolha (veja Microsoft Foundry Quickstart: Criar recursos).
Do topo do parque de diversões de modelos, copie o nome do modelo.
A forma mais fácil de obter o endpoint Azure OpenAI continua a ser através do portal clássico. Selecione o botão de opção New Foundry, depois Azure OpenAI, e depois copie o URL no Azure OpenAI endpoint para mais tarde.
Atribuir permissões necessárias
No menu superior do novo portal da Foundry, selecione Operar, depois selecione Administrador. Na fila do seu projeto Foundry, deve ver dois links. O elemento na coluna Nome é o recurso do projeto Foundry, e o elemento na coluna Recurso Pai é o recurso Foundry.
Selecione o recurso Foundry no recurso Pai e depois selecione Gerir este recurso no portal Azure. A partir do portal Azure, pode atribuir acesso baseado em funções para o recurso à aplicação web implementada.
Adicione o seguinte papel para a identidade gerida da aplicação App Service:
Recurso de destino Função obrigatória Necessário para Fundição Utilizador dos Serviços Cognitivos OpenAI O serviço de conclusão de chat no Microsoft Agent Framework. Para obter instruções, consulte Atribuir funções do Azure utilizando o portal do Azure.
Configurar variáveis de conexão em seu aplicativo de exemplo
Abra .env. Usando os valores que copiou anteriormente do portal Foundry, configure as seguintes variáveis:
Variable Description AZURE_OPENAI_ENDPOINTEndpoint Azure OpenAI (copiado do portal clássico da Foundry). AZURE_OPENAI_DEPLOYMENT_NAMENome do modelo na implementação (copiado da área de testes do modelo no novo portal da Foundry). Note
Para manter o tutorial simples, você usará essas variáveis em .env em vez de substituí-las pelas configurações do aplicativo no Serviço de Aplicativo.
Note
Para manter o tutorial simples, você usará essas variáveis em .env em vez de substituí-las pelas configurações do aplicativo no Serviço de Aplicativo.
Entre no Azure com a CLI do Azure:
az loginIsso permite que a biblioteca de cliente do Azure Identity no código de exemplo receba um token de autenticação para o usuário conectado. Lembre-se de que você adicionou a função necessária para esse usuário anteriormente.
Execute o aplicativo localmente:
npm run build npm startQuando você vir Seu aplicativo em execução na porta 3000 está disponível, selecione Abrir no navegador.
Selecione o link LangGraph Agent e o link Foundry Agent para experimentar a interface de chat. Se receber uma resposta, a sua aplicação está a ligar-se com sucesso ao recurso Microsoft Foundry.
De volta ao espaço de código do GitHub, implante as alterações do seu aplicativo.
azd upNavegue até o aplicativo implantado novamente e teste os agentes de chat.
Limpeza de recursos
Quando terminar de usar o aplicativo, você poderá excluir os recursos do Serviço de Aplicativo para evitar incorrer em custos adicionais:
azd down --purge
Como o modelo do AZD não inclui os recursos do Microsoft Foundry, tens de os apagar manualmente se quiseres.