![]()
Denne lektion vil dække:
Efter at have gennemført denne lektion vil du kunne:
Kodeeksempler til Microsoft Agent Framework (MAF) findes i dette repository under filer xx-python-agent-framework og xx-dotnet-agent-framework.

Microsoft Agent Framework (MAF) er Microsofts samlede framework til opbygning af AI-agenter. Det tilbyder fleksibilitet til at håndtere den brede vifte af agentiske anvendelsestilfælde, der ses både i produktion og forskningsmiljøer, herunder:
For at levere AI-agenter i produktion har MAF også indbyggede funktioner til:
Microsoft Agent Framework fokuserer også på at være interoperabelt ved:
Lad os se på, hvordan disse funktioner anvendes i nogle af de centrale begreber i Microsoft Agent Framework.

Oprettelse af agenter
Agentoprettelse sker ved at definere inferencetjenesten (LLM-udbyder), et sæt instruktioner for AI-agenten at følge, og et tildelt name:
agent = AzureOpenAIChatClient(credential=AzureCliCredential()).create_agent( instructions="You are good at recommending trips to customers based on their preferences.", name="TripRecommender" )
Ovenstående bruger Azure OpenAI, men agenter kan oprettes ved hjælp af en række tjenester, herunder Microsoft Foundry Agent Service:
AzureAIAgentClient(async_credential=credential).create_agent( name="HelperAgent", instructions="You are a helpful assistant." ) as agent
OpenAI Responses, ChatCompletion API’er
agent = OpenAIResponsesClient().create_agent( name="WeatherBot", instructions="You are a helpful weather assistant.", )
agent = OpenAIChatClient().create_agent( name="HelpfulAssistant", instructions="You are a helpful assistant.", )
eller fjernagenter ved brug af A2A-protokollen:
agent = A2AAgent( name=agent_card.name, description=agent_card.description, agent_card=agent_card, url="https://your-a2a-agent-host" )
Kørselsagenter
Agenter køres ved hjælp af metoderne .run eller .run_stream for enten ikke-streaming eller streaming svar.
result = await agent.run("What are good places to visit in Amsterdam?")
print(result.text)
async for update in agent.run_stream("What are the good places to visit in Amsterdam?"):
if update.text:
print(update.text, end="", flush=True)
Hver agentkørsel kan også have muligheder for at tilpasse parametre som max_tokens anvendt af agenten, tools som agenten kan kalde, og endda den model, der bruges til agenten.
Dette er nyttigt i tilfælde, hvor specifikke modeller eller værktøjer kræves for at fuldføre en brugers opgave.
Værktøjer
Værktøjer kan defineres både ved agentdefinitionen:
def get_attractions( location: Annotated[str, Field(description="The location to get the top tourist attractions for")], ) -> str: """Get the top tourist attractions for a given location.""" return f"The top attractions for {location} are."
# Når du opretter en ChatAgent direkte
agent = ChatAgent( chat_client=OpenAIChatClient(), instructions="You are a helpful assistant", tools=[get_attractions]
og også når agenten køres:
result1 = await agent.run( "What's the best place to visit in Seattle?", tools=[get_attractions] # Værktøj leveret kun til denne kørsel )
Agent-tråde
Agent-tråde anvendes til at håndtere samtaler med flere omgange. Tråde kan oprettes enten ved:
get_new_thread(), som muliggør, at tråden kan gemmes over tidFor at oprette en tråd ser koden således ud:
# Opret en ny tråd.
thread = agent.get_new_thread() # Kør agenten med tråden.
response = await agent.run("Hello, I am here to help you book travel. Where would you like to go?", thread=thread)
Du kan derefter serialisere tråden for at gemme den til senere brug:
# Opret en ny tråd.
thread = agent.get_new_thread()
# Kør agenten med tråden.
response = await agent.run("Hello, how are you?", thread=thread)
# Serialiser tråden til opbevaring.
serialized_thread = await thread.serialize()
# Deserialiser trådtilstanden efter indlæsning fra opbevaring.
resumed_thread = await agent.deserialize_thread(serialized_thread)
Agent-middleware
Agenter interagerer med værktøjer og LLM’er for at udføre brugerens opgaver. I visse scenarier ønsker vi at udføre eller spore handlinger imellem disse interaktioner. Agent-middleware muliggør dette igennem:
Funktionsmiddleware
Denne middleware giver os mulighed for at udføre en handling mellem agenten og en funktion/værktøj, som den vil kalde. Et eksempel på brug er, når man ønsker at logge opkaldet til funktionen.
I koden nedenfor definerer next om den næste middleware eller den faktiske funktion skal kaldes.
async def logging_function_middleware(
context: FunctionInvocationContext,
next: Callable[[FunctionInvocationContext], Awaitable[None]],
) -> None:
"""Function middleware that logs function execution."""
# Forbehandling: Log før funktionsudførelse
print(f"[Function] Calling {context.function.name}")
# Fortsæt til næste middleware eller funktionsudførelse
await next(context)
# Efterbehandling: Log efter funktionsudførelse
print(f"[Function] {context.function.name} completed")
Chatmiddleware
Denne middleware giver os mulighed for at udføre eller logge en handling mellem agenten og forespørgsler til LLM’en.
Dette indeholder vigtig information som messages, der sendes til AI-tjenesten.
async def logging_chat_middleware(
context: ChatContext,
next: Callable[[ChatContext], Awaitable[None]],
) -> None:
"""Chat middleware that logs AI interactions."""
# Forbehandling: Log før AI-kald
print(f"[Chat] Sending {len(context.messages)} messages to AI")
# Fortsæt til næste middleware eller AI-tjeneste
await next(context)
# Efterbehandling: Log efter AI-svar
print("[Chat] AI response received")
Agent-hukommelse
Som dækket i lektionen Agentic Memory, er hukommelse et vigtigt element til at gøre agenten i stand til at operere over forskellige kontekster. MAF tilbyder flere forskellige typer hukommelser:
Hukommelse i tråden
Dette er hukommelsen lagret i tråde under applikationskørsel.
# Opret en ny tråd.
thread = agent.get_new_thread() # Kør agenten med tråden.
response = await agent.run("Hello, I am here to help you book travel. Where would you like to go?", thread=thread)
Vedvarende beskeder
Denne hukommelse anvendes til opbevaring af samtalehistorik på tværs af forskellige sessioner. Den defineres ved hjælp af chat_message_store_factory:
from agent_framework import ChatMessageStore
# Opret en brugerdefineret meddelelseslager
def create_message_store():
return ChatMessageStore()
agent = ChatAgent(
chat_client=OpenAIChatClient(),
instructions="You are a Travel assistant.",
chat_message_store_factory=create_message_store
)
Dynamisk hukommelse
Denne hukommelse tilføjes til konteksten, før agenter køres. Disse hukommelser kan gemmes i eksterne tjenester som mem0:
from agent_framework.mem0 import Mem0Provider
# Bruger Mem0 til avancerede hukommelsesfunktioner
memory_provider = Mem0Provider(
api_key="your-mem0-api-key",
user_id="user_123",
application_id="my_app"
)
agent = ChatAgent(
chat_client=OpenAIChatClient(),
instructions="You are a helpful assistant with memory.",
context_providers=memory_provider
)
Agent-observabilitet
Observabilitet er vigtigt for at opbygge pålidelige og vedligeholdbare agentiske systemer. MAF integrerer med OpenTelemetry for at levere tracing og målere til bedre observabilitet.
from agent_framework.observability import get_tracer, get_meter
tracer = get_tracer()
meter = get_meter()
with tracer.start_as_current_span("my_custom_span"):
# gør noget
pass
counter = meter.create_counter("my_custom_counter")
counter.add(1, {"key": "value"})
MAF tilbyder workflows, som er foruddefinerede trin til at fuldføre en opgave, og som inkluderer AI-agenter som komponenter i disse trin.
Workflows består af forskellige komponenter, der tillader bedre kontrolflow. Workflows muliggør også multi-agent orkestrering og checkpointing for at gemme workflow-tilstande.
De centrale komponenter i en workflow er:
Executorer
Executorer modtager inputbeskeder, udfører deres tildelte opgaver og producerer derefter en outputbesked. Dette fører workflowet videre mod at færdiggøre den større opgave. Executorer kan være både AI-agent eller brugerdefineret logik.
Edges
Edges bruges til at definere beskedflow i en workflow. Disse kan være:
Direkte Edges – Enkle en-til-en forbindelser mellem executor:
from agent_framework import WorkflowBuilder
builder = WorkflowBuilder()
builder.add_edge(source_executor, target_executor)
builder.set_start_executor(source_executor)
workflow = builder.build()
Betingede Edges – Aktiveres efter en bestemt betingelse er opfyldt. For eksempel, når hotelværelser ikke er tilgængelige, kan en executor foreslå andre muligheder.
Switch-case Edges – Rute beskeder til forskellige executor baseret på definerede betingelser. For eksempel hvis en rejsekunde har prioriteret adgang, og deres opgaver bliver håndteret gennem en anden workflow.
Fan-out Edges – Sender en besked til flere mål.
Fan-in Edges – Samler flere beskeder fra forskellige executor og sender til ét mål.
Events
For at give bedre observabilitet i workflows tilbyder MAF indbyggede events for eksekvering, herunder:
WorkflowStartedEvent - Workflow eksekvering begynderWorkflowOutputEvent - Workflow producerer en outputWorkflowErrorEvent - Workflow støder på en fejlExecutorInvokeEvent - Executor starter behandlingExecutorCompleteEvent - Executor afslutter behandlingRequestInfoEvent - En forespørgsel udsendesDe ovenstående sektioner dækker de centrale begreber i Microsoft Agent Framework. Når du bygger mere komplekse agenter, er her nogle avancerede mønstre at overveje:
Kodeeksempler til Microsoft Agent Framework findes i dette repository under filer xx-python-agent-framework og xx-dotnet-agent-framework.
Deltag i Microsoft Foundry Discord for at møde andre lærende, deltage i kontortimer og få besvaret dine spørgsmål om AI-agenter.
Ansvarsfraskrivelse: Dette dokument er blevet oversat ved hjælp af AI-oversættelsestjenesten Co-op Translator. Selvom vi stræber efter nøjagtighed, bedes du være opmærksom på, at automatiserede oversættelser kan indeholde fejl eller unøjagtigheder. Det oprindelige dokument på dets modersmål bør betragtes som den autoritative kilde. For kritisk information anbefales professionel menneskelig oversættelse. Vi påtager os intet ansvar for eventuelle misforståelser eller fejltolkninger, der opstår ved brug af denne oversættelse.