Connetti una knowledge base di Foundry IQ al Foundry Agent Service

Importante

Gli elementi contrassegnati (anteprima) in questo articolo sono attualmente in anteprima pubblica. Questa anteprima viene fornita senza un contratto di servizio e non è consigliabile per i carichi di lavoro di produzione. Alcune funzionalità potrebbero non essere supportate o potrebbero avere funzionalità limitate. Per altre informazioni, vedere Condizioni supplementari per l'utilizzo delle anteprime di Microsoft Azure.

Questo articolo illustra come connettere una Knowledge Base in Foundry IQ a un agente nel servizio Foundry Agent. La connessione usa il protocollo MCP (Model Context Protocol) per facilitare le chiamate agli strumenti. Quando viene richiamato dall'agente, la Knowledge Base orchestra le operazioni seguenti:

  • Pianifica e scompone una query utente in sottoquery.
  • Elabora le sottoquery contemporaneamente usando le tecniche di parola chiave, vettore o ibrido.
  • Applica il reranking semantico per identificare i risultati più rilevanti.
  • Sintetizza i risultati in una risposta unificata con riferimenti all'origine.

L'agente utilizza la risposta per basare le sue risposte sui dati aziendali o sulle fonti web, garantendo precisione e trasparenza fattuali tramite l'attribuzione delle fonti.

Per un esempio end-to-end dell'integrazione di Azure AI Search e del servizio agente Foundry per il recupero delle informazioni, vedere l'esempio agentic-retrieval-pipeline-example Python su GitHub.

Supporto per l'utilizzo

Supporto Foundry di Microsoft PYTHON SDK SDK di C# JavaScript SDK JAVA SDK REST API Configurazione dell'agente di base Configurazione dell'agente standard
✔️ ✔️ - - - ✔️ ✔️ ✔️

Prerequisiti

Autenticazione e autorizzazioni

È consigliabile controllare l'accesso in base al ruolo per le distribuzioni di produzione. Se i ruoli non sono fattibili, ignorare questa sezione e usare invece l'autenticazione basata su chiave.

  • Nella risorsa padre del progetto, è necessario il ruolo Utente di Azure AI per accedere alle implementazioni del modello e creare agenti. I proprietari ottengono automaticamente questo ruolo quando creano la risorsa. Altri utenti necessitano di un'assegnazione di ruolo specifica. Per altre informazioni, vedere Controllo degli accessi in base al ruolo nel portale di Foundry.

  • Nella risorsa padre del progetto, è necessario disporre del ruolo Gestione progetti di Azure AI per creare una connessione progetto per l'autenticazione MCP e del ruolo Utente Azure AI o Gestione progetti Azure AI per usare lo strumento MCP negli agenti.

  • Nel progetto creare un'identità gestita assegnata dal sistema per le interazioni con Azure AI Search.

Valori obbligatori

Usare i valori seguenti negli esempi di codice.

Valore Dove ottenerlo Esempio
endpoint di progetto (project_endpoint) Trovarlo nei dettagli del progetto nel portale di Microsoft Foundry. https://your-resource.services.ai.azure.com/api/projects/your-project
ID risorsa del progetto (project_resource_id) Copiare l'ID risorsa arm del progetto dal portale di Azure oppure usare interfaccia della riga di comando di Azure per eseguire query sull'ID risorsa. /subscriptions/.../resourceGroups/.../providers/Microsoft.MachineLearningServices/workspaces/.../projects/...
Endpoint di Azure AI Search (search_service_endpoint) Trovarlo nella pagina del servizio Azure AI Search Overview (URL del servizio) nel portale di Azure. https://your-search-service.search.windows.net
Nome della Knowledge Base (knowledge_base_name) Usare il nome della Knowledge Base che hai creato in Azure AI Search. hr-policy-kb
Nome della connessione del progetto (project_connection_name) Scegliere un nome per la connessione al progetto creata. my-kb-mcp-connection
Nome agente (agent_name) Scegliere un nome per la versione dell'agente creata. hr-assistant
Nome distribuzione del modello (deployed_LLM) Trovalo nelle distribuzioni del modello del progetto Microsoft Foundry. gpt-4.1-mini

Suggerimento

È consigliabile archiviare l'endpoint del progetto, l'endpoint di ricerca e il nome della Knowledge Base in un .env file per lo sviluppo locale.

Creare una connessione al progetto

Creare una connessione RemoteTool nel progetto Microsoft Foundry. Questa connessione usa l'identità gestita del progetto per indirizzare l'endpoint MCP della Knowledge Base, consentendo all'agente di comunicare in modo sicuro con Azure AI Search per le operazioni di recupero.

Nota

La categoria /> sono specifici delle connessioni al progetto Foundry Microsoft.

import requests
from azure.identity import DefaultAzureCredential, get_bearer_token_provider

# Provide connection details
credential = DefaultAzureCredential()
project_resource_id = "{project_resource_id}" # e.g. /subscriptions/{subscription}/resourceGroups/{resource_group}/providers/Microsoft.MachineLearningServices/workspaces/{account_name}/projects/{project_name}
project_connection_name = "{project_connection_name}"
mcp_endpoint = "{search_service_endpoint}/knowledgebases/{knowledge_base_name}/mcp?api-version=2025-11-01-preview" # This endpoint enables the MCP connection between the agent and knowledge base

# Get bearer token for authentication
bearer_token_provider = get_bearer_token_provider(credential, "https://management.azure.com/.default")
headers = {
  "Authorization": f"Bearer {bearer_token_provider()}",
}

# Create project connection
response = requests.put(
  f"https://management.azure.com{project_resource_id}/connections/{project_connection_name}?api-version=2025-10-01-preview",
  headers = headers,
  json = {
    "name": project_connection_name,
    "type": "Microsoft.MachineLearningServices/workspaces/connections",
    "properties": {
      "authType": "ProjectManagedIdentity",
      "category": "RemoteTool",
      "target": mcp_endpoint,
      "isSharedToAll": True,
      "audience": "https://search.azure.com/",
      "metadata": { "ApiType": "Azure" }
    }
  }
)

response.raise_for_status()
print(f"Connection '{project_connection_name}' created or updated successfully.")

Ottimizzare le istruzioni dell'agente per il recupero delle informazioni

Per migliorare le chiamate della Knowledge Base e produrre risposte basate su citazione, iniziare con istruzioni simili alle seguenti:

You are a helpful assistant.

Use the knowledge base tool to answer user questions.
If the knowledge base doesn't contain the answer, respond with "I don't know".

When you use information from the knowledge base, include citations to the retrieved sources.

Questo modello di istruzione è ottimizzato per:

  • Tassi di chiamata allo strumento MCP più elevati: le direttive esplicite assicurano che l'agente chiami costantemente lo strumento della Knowledge Base anziché basarsi sui dati di training.
  • Attribuzione chiara dell'origine: le citazioni semplificano la convalida della provenienza delle informazioni.

Suggerimento

Sebbene questo modello fornisca una base solida, valuta e itera sulle istruzioni a seconda del tuo caso d'uso specifico e degli obiettivi. Testare diverse varianti per trovare le migliori prestazioni per lo scenario in uso.

Creare un agente con lo strumento MCP

Creare un agente che integra la Knowledge Base come strumento MCP. L'agente usa un prompt di sistema per indicare quando e come chiamare la Knowledge Base. Segue le istruzioni su come rispondere alle domande e gestisce automaticamente la configurazione e le impostazioni degli strumenti nelle sessioni di conversazione.

Aggiungere lo strumento MCP della Knowledge Base con la connessione al progetto creata in precedenza. Questo strumento orchestra la pianificazione delle query, la scomposizione e il recupero delle informazioni tra le fonti di conoscenza configurate. L'agente usa questo strumento per rispondere alle query.

Nota

Le basi di conoscenza di Azure AI Search rendono disponibile lo strumento MCP knowledge_base_retrieve per l'integrazione dell'agente. Questo è l'unico strumento attualmente supportato per l'uso con il servizio agente Foundry.

from azure.ai.projects import AIProjectClient
from azure.ai.projects.models import PromptAgentDefinition, MCPTool
from azure.identity import DefaultAzureCredential

# Provide agent configuration details
credential = DefaultAzureCredential()
mcp_endpoint = "{search_service_endpoint}/knowledgebases/{knowledge_base_name}/mcp?api-version=2025-11-01-preview"
project_endpoint = "{project_endpoint}" # e.g. https://your-foundry-resource.services.ai.azure.com/api/projects/your-foundry-project
project_connection_name = "{project_connection_name}"
agent_name = "{agent_name}"
agent_model = "{deployed_LLM}" # e.g. gpt-4.1-mini

# Create project client
project_client = AIProjectClient(endpoint = project_endpoint, credential = credential)

# Define agent instructions (see "Optimize agent instructions" section for guidance)
instructions = """
You are a helpful assistant that must use the knowledge base to answer all the questions from user. You must never answer from your own knowledge under any circumstances.
Every answer must always provide annotations for using the MCP knowledge base tool and render them as: `【message_idx:search_idx†source_name】`
If you cannot find the answer in the provided knowledge base you must respond with "I don't know".
"""

# Create MCP tool with knowledge base connection
mcp_kb_tool = MCPTool(
    server_label = "knowledge-base",
    server_url = mcp_endpoint,
    require_approval = "never",
    allowed_tools = ["knowledge_base_retrieve"],
    project_connection_id = project_connection_name
)

# Create agent with MCP tool
agent = project_client.agents.create_version(
    agent_name = agent_name,
    definition = PromptAgentDefinition(
        model = agent_model,
        instructions = instructions,
        tools = [mcp_kb_tool]
    )
)

print(f"Agent '{agent_name}' created or updated successfully.")

Collegarsi a una fonte di informazioni remota di SharePoint

Importante

In questa anteprima il servizio Foundry Agent non supporta le intestazioni per richiesta per gli strumenti MCP. Le intestazioni impostate nelle definizioni dell'agente si applicano a tutte le chiamate e non possono variare in base all'utente o alla richiesta.

Per l'autorizzazione per utente, usare Azure OpenAI Responses API invece.

Facoltativamente, se la Knowledge Base include un'origine di conoscenza SharePoint remota, è necessario includere anche l'intestazione x-ms-query-source-authorization nella connessione con lo strumento MCP. Per altre informazioni, vedere Applicare le autorizzazioni in fase di query.

from azure.identity import get_bearer_token_provider

# Create MCP tool with SharePoint authorization header
mcp_kb_tool = MCPTool(
    server_label = "knowledge-base",
    server_url = mcp_endpoint,
    require_approval = "never",
    allowed_tools = ["knowledge_base_retrieve"],
    project_connection_id = project_connection_name,
    headers = {
        "x-ms-query-source-authorization": get_bearer_token_provider(credential, "https://search.azure.com/.default")()
    }
)

Richiamare l'agente con una query

Creare una sessione di conversazione e inviare una query utente all'agente. Se appropriato, l'agente orchestra le chiamate allo strumento MCP per recuperare il contenuto pertinente dalla Knowledge Base. L'agente sintetizza quindi questo contenuto in una risposta in linguaggio naturale che cita i documenti di origine.

Gli URL di citazione nelle risposte dell'agente variano in base all'origine delle informazioni. Ad esempio, le fonti di conoscenza BLOB restituiscono l'URL del documento originale, mentre le fonti di conoscenza dell'indice di ricerca restituiscono l'endpoint MCP della knowledge base.

# Get the OpenAI client for responses and conversations
openai_client = project_client.get_openai_client()

# Create conversation
conversation = openai_client.conversations.create()

# Send request to trigger the MCP tool
response = openai_client.responses.create(
    conversation = conversation.id,
    input = """
        Why do suburban belts display larger December brightening than urban cores even though absolute light levels are higher downtown?
        Why is the Phoenix nighttime street grid is so sharply visible from space, whereas large stretches of the interstate between midwestern cities remain comparatively dim?
    """,
    extra_body = {"agent_reference": {"name": agent.name, "type": "agent_reference"}},
)

print(f"Response: {response.output_text}")

L'output dovrebbe essere simile al seguente (troncato per brevità):

Response: Suburban belts display larger December brightening than urban cores, even 
though absolute light levels are higher downtown, primarily because holiday lights 
increase most dramatically in the suburbs and outskirts of major cities. This is due 
to more yard space and a prevalence of single-family homes in suburban areas...

The Phoenix nighttime street grid is sharply visible from space due to the city's 
layout along a regular grid of city blocks and streets with extensive street lighting...

References:
- earth_at_night_508_page_174, earth_at_night_508_page_176 (Holiday lighting)
- earth_at_night_508_page_104, earth_at_night_508_page_105 (Phoenix grid visibility)

Eliminare l'agente e la connessione al progetto

# Delete the agent
project_client.agents.delete_version(agent_name=agent.name, agent_version=agent.version)
print(f"Agent '{agent.name}' version '{agent.version}' deleted successfully.")

# Delete the project connection (Azure Resource Manager)
import requests
from azure.identity import DefaultAzureCredential, get_bearer_token_provider

credential = DefaultAzureCredential()
project_resource_id = "{project_resource_id}"
project_connection_name = "{project_connection_name}"

bearer_token_provider = get_bearer_token_provider(credential, "https://management.azure.com/.default")
headers = {"Authorization": f"Bearer {bearer_token_provider()}"}

response = requests.delete(
  f"https://management.azure.com{project_resource_id}/connections/{project_connection_name}?api-version=2025-10-01-preview",
  headers=headers,
)
response.raise_for_status()
print(f"Project connection '{project_connection_name}' deleted successfully.")

Nota

L'eliminazione dell'agente e della connessione al progetto non comporta l'eliminazione della Knowledge Base o delle relative origini conoscenze. È necessario eliminare questi oggetti separatamente nel servizio Azure AI Search. Per ulteriori informazioni, consultare Eliminare una base di conoscenza e Eliminare una fonte di conoscenza.

Risoluzione dei problemi

Questa sezione consente di risolvere i problemi comuni relativi alla connessione del servizio Foundry Agent a una Knowledge Base di IQ Foundry.

Errori di autorizzazione (401/403)

  • Se si riceve un errore 403 da Azure AI Search, assicurarsi che l'identità gestita del progetto disponga del ruolo Lettore dati indice di ricerca per il servizio di ricerca (e Collaboratore dati indice di ricerca se si scrive negli indici).
  • Se si ottiene un valore 403 da Azure Resource Manager quando si crea o si elimina la connessione al progetto, verificare che l'utente o l'entità servizio disponga delle autorizzazioni per la risorsa e il progetto di Microsoft Foundry.
  • Se usi l'autenticazione senza chiave, verifica che l'ambiente sia autenticato nel tenant e nella sottoscrizione corretti.

Errori degli endpoint MCP (400/404)

  • Verificare che search_service_endpoint sia l'URL del servizio Azure AI Search, ad esempio https://<name>.search.windows.net.
  • Verificare che knowledge_base_name corrisponda alla knowledge base creata in Azure AI Search.
  • Verificare di usare la versione dell'API 2025-11-01-preview per l'endpoint MCP della Knowledge Base.

L'agente non contestualizza le risposte

  • Verificare che l'agente abbia configurato lo strumento MCP e allowed_tools includa knowledge_base_retrieve.
  • Aggiornare le istruzioni dell'agente per richiedere in modo esplicito l'uso della Knowledge Base e per restituire "Non so" quando il recupero non contiene la risposta.