![]()
Această lecție va acoperi:
După finalizarea acestei lecții, vei ști cum să:
Exemplele de cod pentru Microsoft Agent Framework (MAF) pot fi găsite în acest depozit sub fișierele xx-python-agent-framework și xx-dotnet-agent-framework.

Microsoft Agent Framework (MAF) este cadrul unificat al Microsoft pentru construirea agenților AI. Oferă flexibilitatea de a aborda o gamă largă de cazuri de utilizare agentică întâlnite atât în producție, cât și în medii de cercetare, incluzând:
Pentru a livra agenți AI în producție, MAF include și caracteristici pentru:
Microsoft Agent Framework este de asemenea axat pe interoperabilitate prin:
Să vedem cum sunt aplicate aceste caracteristici în unele dintre conceptele cheie ale Microsoft Agent Framework.

Crearea agenților
Crearea unui agent se realizează prin definirea serviciului de inferență (furnizor LLM), un set de instrucțiuni pe care agentul AI trebuie să le urmeze și atribuirea unui name:
agent = AzureOpenAIChatClient(credential=AzureCliCredential()).create_agent( instructions="You are good at recommending trips to customers based on their preferences.", name="TripRecommender" )
Mai sus se folosește Azure OpenAI dar agenții pot fi creați folosind o varietate de servicii inclusiv Microsoft Foundry Agent Service:
AzureAIAgentClient(async_credential=credential).create_agent( name="HelperAgent", instructions="You are a helpful assistant." ) as agent
OpenAI Responses, API-urile ChatCompletion
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.", )
sau MiniMax, care oferă un API compatibil OpenAI cu ferestre mari de context (până la 204K tokens):
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.", )
sau agenți la distanță folosind protocolul A2A:
agent = A2AAgent( name=agent_card.name, description=agent_card.description, agent_card=agent_card, url="https://your-a2a-agent-host" )
Rularea agenților
Agenții sunt rulați folosind metodele .run sau .run_stream pentru răspunsuri non-streaming sau streaming.
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)
Fiecare rulare a unui agent poate avea opțiuni pentru a personaliza parametri precum max_tokens folosiți de agent, tools pe care agentul le poate apela și chiar modelul (model) însuși folosit pentru agent.
Acest lucru este util în cazurile în care sunt necesare modele sau instrumente specifice pentru îndeplinirea sarcinii utilizatorului.
Instrumente
Instrumentele pot fi definite atât la definirea agentului:
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."
# Când creați un ChatAgent direct
agent = ChatAgent( chat_client=OpenAIChatClient(), instructions="You are a helpful assistant", tools=[get_attractions]
cât și la rularea agentului:
result1 = await agent.run( "What's the best place to visit in Seattle?", tools=[get_attractions] # Unealtă oferită doar pentru această execuție )
Firele agentului
Firele agentului sunt folosite pentru a gestiona conversații cu mai multe runde. Firele pot fi create prin:
get_new_thread() care permite salvarea firului în timpPentru a crea un fir, codul arată astfel:
# Creați un fir nou.
thread = agent.get_new_thread() # Rulați agentul cu firul.
response = await agent.run("Hello, I am here to help you book travel. Where would you like to go?", thread=thread)
Apoi poți serializa firul pentru a fi stocat pentru utilizare ulterioară:
# Creează un fir nou.
thread = agent.get_new_thread()
# Rulează agentul cu firul.
response = await agent.run("Hello, how are you?", thread=thread)
# Seriază firul pentru stocare.
serialized_thread = await thread.serialize()
# Deseriază starea firului după încărcarea din stocare.
resumed_thread = await agent.deserialize_thread(serialized_thread)
Middleware agent
Agenții interacționează cu instrumente și LLM-uri pentru a îndeplini sarcinile utilizatorului. În anumite scenarii, dorim să executăm sau să urmărim interacțiunile dintre acestea. Middleware-ul de agent ne permite acest lucru prin:
Middleware funcție
Acest middleware ne permite să executăm o acțiune între agent și o funcție/instrument pe care acesta îl va apela. Un exemplu este dorința de a face logare asupra apelului funcției.
În codul de mai jos next definește dacă următorul middleware sau funcția efectivă trebuie apelată.
async def logging_function_middleware(
context: FunctionInvocationContext,
next: Callable[[FunctionInvocationContext], Awaitable[None]],
) -> None:
"""Function middleware that logs function execution."""
# Preprocesare: Înregistrare înainte de execuția funcției
print(f"[Function] Calling {context.function.name}")
# Continuă la următorul middleware sau execuția funcției
await next(context)
# Postprocesare: Înregistrare după execuția funcției
print(f"[Function] {context.function.name} completed")
Middleware chat
Acest middleware ne permite să executăm sau să înregistrăm o acțiune între agent și cererile dintre LLM.
Aceasta conține informații importante precum messages care sunt trimise către serviciul AI.
async def logging_chat_middleware(
context: ChatContext,
next: Callable[[ChatContext], Awaitable[None]],
) -> None:
"""Chat middleware that logs AI interactions."""
# Pre-procesare: Log de dinaintea apelului AI
print(f"[Chat] Sending {len(context.messages)} messages to AI")
# Continuă către următorul middleware sau serviciu AI
await next(context)
# Post-procesare: Log după răspunsul AI
print("[Chat] AI response received")
Memoria agentului
Așa cum a fost acoperit în lecția Agentic Memory, memoria este un element important pentru a permite agentului să opereze în contexte diferite. MAF oferă mai multe tipuri de memorii:
Stocare în memorie
Aceasta este memoria stocată în fire în timpul rulării aplicației.
# Creează un nou thread.
thread = agent.get_new_thread() # Rulează agentul cu thread-ul.
response = await agent.run("Hello, I am here to help you book travel. Where would you like to go?", thread=thread)
Mesaje persistente
Această memorie este folosită atunci când se stochează istoricul conversațiilor între sesiuni diferite. Este definită folosind chat_message_store_factory:
from agent_framework import ChatMessageStore
# Creează un magazin de mesaje personalizat
def create_message_store():
return ChatMessageStore()
agent = ChatAgent(
chat_client=OpenAIChatClient(),
instructions="You are a Travel assistant.",
chat_message_store_factory=create_message_store
)
Memorie dinamică
Această memorie este adăugată în context înainte ca agenții să fie rulați. Aceste memorii pot fi stocate în servicii externe precum mem0:
from agent_framework.mem0 import Mem0Provider
# Utilizarea Mem0 pentru capacități avansate de memorie
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
)
Observabilitatea agentului
Observabilitatea este importantă pentru construirea unor sisteme agentice fiabile și ușor de întreținut. MAF se integrează cu OpenTelemetry pentru a oferi trasabilitate și contoare pentru o observabilitate mai bună.
from agent_framework.observability import get_tracer, get_meter
tracer = get_tracer()
meter = get_meter()
with tracer.start_as_current_span("my_custom_span"):
# fă ceva
pass
counter = meter.create_counter("my_custom_counter")
counter.add(1, {"key": "value"})
MAF oferă fluxuri de lucru care sunt pași predefiniți pentru a finaliza o sarcină și includ agenți AI ca componente în acești pași.
Fluxurile de lucru sunt compuse din diferite componente care permit un control mai bun al fluxului. De asemenea, fluxurile de lucru permit orchestrarea multi-agent și checkpointing pentru a salva stările fluxului de lucru.
Componentele de bază ale unui flux de lucru sunt:
Executorii
Executorii primesc mesaje de intrare, execută sarcinile alocate și apoi produc un mesaj de ieșire. Acesta avansează fluxul de lucru către finalizarea sarcinii mai mari. Executorii pot fi agenți AI sau logică personalizată.
Muchii
Muchiile sunt folosite pentru a defini fluxul mesajelor într-un flux de lucru. Acestea pot fi:
Muchii directe - Conexiuni simple unu-la-unu între executori:
from agent_framework import WorkflowBuilder
builder = WorkflowBuilder()
builder.add_edge(source_executor, target_executor)
builder.set_start_executor(source_executor)
workflow = builder.build()
Muchii condiționale - Activează după ce o anumită condiție este îndeplinită. De exemplu, când camerele de hotel nu sunt disponibile, un executor poate sugera alte opțiuni.
Muchii switch-case - Direcționează mesajele către executori diferiți pe baza condițiilor definite. De exemplu, dacă un client de călătorie are acces prioritar, sarcinile sale vor fi gestionate printr-un alt flux de lucru.
Muchii fan-out - Trimit un mesaj către mai multe destinații.
Muchii fan-in - Colectează mai multe mesaje de la diverși executori și le trimite către o singură destinație.
Evenimente
Pentru a oferi o mai bună observabilitate în fluxurile de lucru, MAF oferă evenimente încorporate pentru execuție cum ar fi:
WorkflowStartedEvent - Execuția fluxului de lucru începeWorkflowOutputEvent - Fluxul de lucru produce un outputWorkflowErrorEvent - Fluxul de lucru întâmpină o eroareExecutorInvokeEvent - Executorul începe procesareaExecutorCompleteEvent - Executorul termină procesareaRequestInfoEvent - O cerere este emisăSecțiunile de mai sus acoperă conceptele cheie ale Microsoft Agent Framework. Pe măsură ce construiești agenți mai complexi, iată câteva modele avansate de luat în considerare:
Exemplele de cod pentru Microsoft Agent Framework pot fi găsite în acest depozit sub fișierele xx-python-agent-framework și xx-dotnet-agent-framework.
Alătură-te Microsoft Foundry Discord pentru a întâlni alți cursanți, a participa la orele de birou și a primi răspunsuri la întrebările tale despre agenții AI.
Declinare de responsabilitate:
Acest document a fost tradus folosind serviciul de traducere AI Co-op Translator. Deși ne străduim pentru acuratețe, vă rugăm să fiți conștienți că traducerile automate pot conține erori sau inexactități. Documentul original în limba sa nativă trebuie considerat sursa autoritară. Pentru informații critice, se recomandă traducerea profesională realizată de un specialist uman. Nu ne asumăm răspunderea pentru eventualele neînțelegeri sau interpretări eronate care pot apărea în urma utilizării acestei traduceri.