![]()
Tato lekce pokryje:
Po dokončení této lekce budete vědět, jak:
Ukázky kódu pro Microsoft Agent Framework (MAF) naleznete v tomto repozitáři pod soubory xx-python-agent-framework a xx-dotnet-agent-framework.

Microsoft Agent Framework (MAF) je jednotný rámec Microsoftu pro vytváření AI agentů. Nabízí flexibilitu řešit širokou škálu agentních případů použití jak v produkčním, tak výzkumném prostředí, včetně:
Pro dodání AI agentů do produkce má MAF také zahrnuté funkce pro:
Microsoft Agent Framework se také zaměřuje na interoperabilitu tím, že je:
Pojďme se podívat, jak jsou tyto funkce aplikovány na základní koncepty Microsoft Agent Framework.

Vytváření agentů
Vytvoření agenta se provádí definováním inference služby (LLM poskytovatel),
sady instrukcí, které má AI agent následovat a přiřazeným name:
agent = AzureOpenAIChatClient(credential=AzureCliCredential()).create_agent( instructions="You are good at recommending trips to customers based on their preferences.", name="TripRecommender" )
Výše je použit Azure OpenAI, ale agenti mohou být vytvořeni pomocí různých služeb včetně Microsoft Foundry Agent Service:
AzureAIAgentClient(async_credential=credential).create_agent( name="HelperAgent", instructions="You are a helpful assistant." ) as agent
OpenAI Responses, ChatCompletion API
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.", )
nebo MiniMax, který nabízí OpenAI-kompatibilní API s velkými kontextovými okny (až 204K tokenů):
agent = OpenAIChatClient(base_url="https://api.minimax.io/v1", api_key=os.environ["MINIMAX_API_KEY"], model_id="MiniMax-M2.7").create_agent( name="HelpfulAssistant", instructions="You are a helpful assistant.", )
nebo vzdálených agentů pomocí protokolu A2A:
agent = A2AAgent( name=agent_card.name, description=agent_card.description, agent_card=agent_card, url="https://your-a2a-agent-host" )
Spouštění agentů
Agenti se spouštějí pomocí metod .run nebo .run_stream pro ne-streamované nebo streamované odpovědi.
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)
Každé spuštění agenta může mít také možnosti přizpůsobení parametrů jako max_tokens použité agentem, tools, které může agent volat, a dokonce i samotný model, který agent používá.
To je užitečné v případech, kdy jsou vyžadovány specifické modely nebo nástroje k dokončení uživatelského úkolu.
Nástroje
Nástroje mohou být definovány jak při definování agenta:
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."
# Při přímém vytváření ChatAgenta
agent = ChatAgent( chat_client=OpenAIChatClient(), instructions="You are a helpful assistant", tools=[get_attractions]
tak i při spouštění agenta:
result1 = await agent.run( "What's the best place to visit in Seattle?", tools=[get_attractions] # Nástroj poskytnutý pouze pro tento běh )
Vlákna agenta
Vlákna agentů se používají pro zpracování rozhovorů s více kroky. Vlákna lze vytvořit buď:
get_new_thread(), které umožňuje vlákno ukládat v časePro vytvoření vlákna vypadá kód takto:
# Vytvořit nový vlákno.
thread = agent.get_new_thread() # Spusťte agenta pomocí vlákna.
response = await agent.run("Hello, I am here to help you book travel. Where would you like to go?", thread=thread)
Vlákno pak můžete serializovat a uložit pro pozdější použití:
# Vytvořit nový vláknový proces.
thread = agent.get_new_thread()
# Spusťte agenta s vláknem.
response = await agent.run("Hello, how are you?", thread=thread)
# Serializujte vlákno pro uložení.
serialized_thread = await thread.serialize()
# Deserializujte stav vlákna po načtení z úložiště.
resumed_thread = await agent.deserialize_thread(serialized_thread)
Middleware agenta
Agent interaguje s nástroji a LLM k dokončení uživatelských úkolů. V určitých scénářích chceme spouštět nebo sledovat tyto interakce. Middleware agenta nám to umožňuje díky:
Funkčnímu middleware
Tento middleware dovoluje provést akci mezi agentem a funkcí/nástrojem, který volá. Příklad použití je, když chcete logovat volání funkce.
V kódu níže next určuje, zda má být zavolán další middleware nebo samotná funkce.
async def logging_function_middleware(
context: FunctionInvocationContext,
next: Callable[[FunctionInvocationContext], Awaitable[None]],
) -> None:
"""Function middleware that logs function execution."""
# Předzpracování: Záznam před vykonáním funkce
print(f"[Function] Calling {context.function.name}")
# Pokračovat na další middleware nebo vykonání funkce
await next(context)
# Pozpracování: Záznam po vykonání funkce
print(f"[Function] {context.function.name} completed")
Chat middleware
Tento middleware dovoluje vykonávat nebo logovat akci mezi agentem a požadavky mezi LLM.
Obsahuje důležité informace jako messages, které jsou posílány AI službě.
async def logging_chat_middleware(
context: ChatContext,
next: Callable[[ChatContext], Awaitable[None]],
) -> None:
"""Chat middleware that logs AI interactions."""
# Předzpracování: Protokolování před voláním AI
print(f"[Chat] Sending {len(context.messages)} messages to AI")
# Pokračovat na další middleware nebo AI službu
await next(context)
# Pozpracování: Protokolování po odpovědi AI
print("[Chat] AI response received")
Paměť agenta
Jak bylo pokryto v lekci Agentic Memory, paměť je důležitým prvkem k umožnění agenta operovat v různých kontextech. MAF nabízí několik druhů pamětí:
Paměť v paměti (In-Memory Storage)
Paměť je uchovávána ve vláknech během běhu aplikace.
# Vytvořit nový vlákno.
thread = agent.get_new_thread() # Spustit agenta s vláknem.
response = await agent.run("Hello, I am here to help you book travel. Where would you like to go?", thread=thread)
Trvalé zprávy (Persistent Messages)
Tato paměť se používá pro ukládání historie konverzací napříč různými relacemi. Definuje se pomocí chat_message_store_factory:
from agent_framework import ChatMessageStore
# Vytvořte vlastní úložiště zpráv
def create_message_store():
return ChatMessageStore()
agent = ChatAgent(
chat_client=OpenAIChatClient(),
instructions="You are a Travel assistant.",
chat_message_store_factory=create_message_store
)
Dynamická paměť
Tato paměť je přidána do kontextu před spuštěním agentů. Tyto paměti mohou být uloženy v externích službách jako mem0:
from agent_framework.mem0 import Mem0Provider
# Používání Mem0 pro pokročilé paměťové schopnosti
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
)
Pozorovatelnost agenta
Pozorovatelnost je důležitá pro vytváření spolehlivých a udržitelných agentních systémů. MAF integruje OpenTelemetry, aby poskytoval trasování a metry pro lepší pozorovatelnost.
from agent_framework.observability import get_tracer, get_meter
tracer = get_tracer()
meter = get_meter()
with tracer.start_as_current_span("my_custom_span"):
# udělej něco
pass
counter = meter.create_counter("my_custom_counter")
counter.add(1, {"key": "value"})
MAF nabízí pracovní postupy, které jsou předdefinované kroky k dokončení úkolu a zahrnují AI agenty jako komponenty těchto kroků.
Pracovní postupy jsou složeny z různých komponent, které umožňují lepší kontrolu toku. Pracovní postupy také umožňují multi-agentní orchestraci a kontrolní body pro ukládání stavů workflow.
Základní komponenty workflow jsou:
Prováděči (Executors)
Prováděči přijímají vstupní zprávy, provádí přiřazené úkoly a poté generují výstupní zprávu. Posouvají workflow směrem k dokončení většího úkolu. Prováděči mohou být AI agent nebo vlastní logika.
Hrany (Edges)
Hrany slouží k definici toku zpráv v workflow. Mohou být:
Přímé hrany - jednoduchá spojení jeden na jednoho mezi prováděči:
from agent_framework import WorkflowBuilder
builder = WorkflowBuilder()
builder.add_edge(source_executor, target_executor)
builder.set_start_executor(source_executor)
workflow = builder.build()
Podmíněné hrany - aktivují se, když je splněna určitá podmínka. Například pokud nejsou dostupné pokoj v hotelu, může prováděč navrhnout jiné možnosti.
Přepínačové hrany (Switch-case) - směrují zprávy k různým prováděčům na základě definovaných podmínek. Například pokud má zákazník s prioritou přístup a jeho úkoly budou řešeny jiným workflow.
Vyzařovací hrany (Fan-out) - posílají jednu zprávu na více cílů.
Sběrné hrany (Fan-in) - sbírají vícero zpráv od různých prováděčů a posílají je jednomu cíli.
Události
Pro lepší pozorovatelnost workflow nabízí MAF vestavěné události pro exekuci včetně:
WorkflowStartedEvent - Spuštění vykonávání workflowWorkflowOutputEvent - Workflow produkuje výstupWorkflowErrorEvent - Workflow narazí na chybuExecutorInvokeEvent - Prováděč začíná zpracováníExecutorCompleteEvent - Prováděč dokončil zpracováníRequestInfoEvent - Vykonán požadavekVýše uvedené sekce pokrývají základní koncepty Microsoft Agent Framework. Jak vytváříte složitější agenty, zde je několik pokročilých vzorů k zamyšlení:
Ukázky kódu pro Microsoft Agent Framework naleznete v tomto repozitáři pod soubory xx-python-agent-framework a xx-dotnet-agent-framework.
Připojte se k Microsoft Foundry Discord, kde se můžete setkat s dalšími studenty, účastnit se konzultací a získat odpovědi na své otázky ohledně AI agentů.
Upozornění:
Tento dokument byl přeložen pomocí AI překladatelské služby Co-op Translator. I když usilujeme o přesnost, mějte prosím na paměti, že automatické překlady mohou obsahovat chyby nebo nepřesnosti. Originální dokument v jeho rodném jazyce by měl být považován za autoritativní zdroj. Pro kritické informace se doporučuje profesionální lidský překlad. Nejsme odpovědni za jakékoli nedorozumění nebo chybné výklady vzniklé používáním tohoto překladu.