<?xml version="1.0" encoding="utf-8" standalone="yes"?><rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom" xmlns:content="http://purl.org/rss/1.0/modules/content/"><channel><title>Durable Task | The .NET Blog</title><link>https://thedotnetblog.com/ca/tags/durable-task/</link><description>Articles, tutorials and insights from the .NET community.</description><generator>Hugo</generator><language>ca</language><managingEditor>@thedotnetblog (The .NET Blog)</managingEditor><webMaster>@thedotnetblog</webMaster><lastBuildDate>Sun, 31 May 2026 00:00:00 +0000</lastBuildDate><atom:link href="https://thedotnetblog.com/ca/tags/durable-task/index.xml" rel="self" type="application/rss+xml"/><item><title>Flux de Treball Duradors en Microsoft Agent Framework: De In-Memory a Azure Functions</title><link>https://thedotnetblog.com/ca/news/emiliano-montesdeoca/maf-durable-workflows-azure-functions-durable-task/</link><pubDate>Sun, 31 May 2026 00:00:00 +0000</pubDate><author>Emiliano Montesdeoca</author><guid>https://thedotnetblog.com/ca/news/emiliano-montesdeoca/maf-durable-workflows-azure-functions-durable-task/</guid><description>El model de programació de flux de treball de MAF ara suporta l'execució duradora respaldada per Durable Task — aquí es mostra com construir fluxos de treball d'agents composables que sobreviuen a reinicis de processos i escalen a Azure Functions.</description><content:encoded>&lt;p&gt;Un dels punts dolorosos dels primers fluxos de treball d&amp;rsquo;agents d&amp;rsquo;IA: són fràgils. Un flux de treball de múltiples passos de llarga durada vinculat a un únic procés significa que el reinici del procés = estat perdut. Per a demostracions simples és correcte. Per a càrregues de treball en producció no ho és.&lt;/p&gt;
&lt;p&gt;El model de programació de fluxos de treball de Microsoft Agent Framework ara suporta l&amp;rsquo;&lt;strong&gt;execució duradora&lt;/strong&gt;, respaldada pel framework Durable Task, amb allotjament a Azure Functions. Aquí s&amp;rsquo;explica com funciona el model de programació i per qué importa la història de la durabilitat.&lt;/p&gt;
&lt;h2 id="els-blocs-de-construcció-bàsics"&gt;Els Blocs de Construcció Bàsics&lt;/h2&gt;
&lt;p&gt;Els &lt;strong&gt;Executor&lt;/strong&gt; són la unitat fonamental de treball. Cada un té tipus — pren una entrada específica i produeix una sortida específica:&lt;/p&gt;
&lt;div class="highlight"&gt;&lt;pre tabindex="0" class="chroma"&gt;&lt;code class="language-csharp" data-lang="csharp"&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;&lt;span class="k"&gt;using&lt;/span&gt; &lt;span class="nn"&gt;Microsoft.Agents.AI.Workflows&lt;/span&gt;&lt;span class="p"&gt;;&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;&lt;span class="kd"&gt;internal&lt;/span&gt; &lt;span class="kd"&gt;sealed&lt;/span&gt; &lt;span class="k"&gt;class&lt;/span&gt; &lt;span class="nc"&gt;OrderLookup&lt;/span&gt;&lt;span class="p"&gt;()&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt; &lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="n"&gt;Executor&lt;/span&gt;&lt;span class="p"&gt;&amp;lt;&lt;/span&gt;&lt;span class="n"&gt;OrderCancelRequest&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="n"&gt;Order&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;(&lt;/span&gt;&lt;span class="s"&gt;&amp;#34;OrderLookup&amp;#34;&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;&lt;span class="p"&gt;{&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt; &lt;span class="kd"&gt;public&lt;/span&gt; &lt;span class="kd"&gt;override&lt;/span&gt; &lt;span class="kd"&gt;async&lt;/span&gt; &lt;span class="n"&gt;ValueTask&lt;/span&gt;&lt;span class="p"&gt;&amp;lt;&lt;/span&gt;&lt;span class="n"&gt;Order&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;&lt;/span&gt; &lt;span class="n"&gt;HandleAsync&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt; &lt;span class="n"&gt;OrderCancelRequest&lt;/span&gt; &lt;span class="n"&gt;message&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt; &lt;span class="n"&gt;IWorkflowContext&lt;/span&gt; &lt;span class="n"&gt;context&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt; &lt;span class="n"&gt;CancellationToken&lt;/span&gt; &lt;span class="n"&gt;cancellationToken&lt;/span&gt; &lt;span class="p"&gt;=&lt;/span&gt; &lt;span class="k"&gt;default&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt; &lt;span class="p"&gt;{&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt; &lt;span class="c1"&gt;// cercar la comanda, retornar-la&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt; &lt;span class="k"&gt;return&lt;/span&gt; &lt;span class="k"&gt;new&lt;/span&gt; &lt;span class="n"&gt;Order&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="n"&gt;Id&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="n"&gt;message&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="n"&gt;OrderId&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="p"&gt;...);&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt; &lt;span class="p"&gt;}&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;&lt;span class="p"&gt;}&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/div&gt;&lt;p&gt;Els &lt;strong&gt;Workflow&lt;/strong&gt; connecten executors en grafs dirigits usant un constructor fluent. El framework gestiona l&amp;rsquo;execució, el flux de dades entre passos i la propagació d&amp;rsquo;errors.&lt;/p&gt;
&lt;p&gt;Podeu modelar:&lt;/p&gt;
&lt;ul&gt;
&lt;li&gt;Cadenes seqüencials (pas A → pas B → pas C)&lt;/li&gt;
&lt;li&gt;Fan-out/fan-in paral·lel (executar agents A, B, C en paral·lel, agregar resultats)&lt;/li&gt;
&lt;li&gt;Ramificació condicional&lt;/li&gt;
&lt;li&gt;Aprovacions de persona en el bucle (pausar flux de treball, esperar senyal extern)&lt;/li&gt;
&lt;/ul&gt;
&lt;h2 id="el-runner-in-memory-per-al-desenvolupament-local"&gt;El Runner In-Memory per al Desenvolupament Local&lt;/h2&gt;
&lt;p&gt;Començar és ràpid:&lt;/p&gt;
&lt;div class="highlight"&gt;&lt;pre tabindex="0" class="chroma"&gt;&lt;code class="language-csharp" data-lang="csharp"&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;&lt;span class="n"&gt;dotnet&lt;/span&gt; &lt;span class="k"&gt;add&lt;/span&gt; &lt;span class="n"&gt;package&lt;/span&gt; &lt;span class="n"&gt;Microsoft&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="n"&gt;Agents&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="n"&gt;AI&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;&lt;span class="n"&gt;dotnet&lt;/span&gt; &lt;span class="k"&gt;add&lt;/span&gt; &lt;span class="n"&gt;package&lt;/span&gt; &lt;span class="n"&gt;Microsoft&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="n"&gt;Agents&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="n"&gt;AI&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="n"&gt;Workflows&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/div&gt;&lt;p&gt;El paquet principal inclou un runner lleuger en procés. Sense dependències externes, sense base de dades, sense recursos Azure. Funciona perfectament per al desenvolupament local i les proves unitàries.&lt;/p&gt;
&lt;h2 id="afegir-durabilitat-amb-durable-task"&gt;Afegir Durabilitat amb Durable Task&lt;/h2&gt;
&lt;p&gt;Quan un flux de treball necessita sobreviure a reinicis de procés — perquè és de llarga durada, perquè té passos de persona en el bucle, perquè es distribueix en moltes crides d&amp;rsquo;agent en paral·lel — el runner in-memory no és suficient.&lt;/p&gt;
&lt;p&gt;La integració de Durable Task de MAF emmagatzema l&amp;rsquo;estat del flux de treball a Azure Storage. Si el procés es reinicia, el flux de treball reprèn des d&amp;rsquo;on va quedar. El model de programació roman igual; simplement canvieu el runner.&lt;/p&gt;
&lt;div class="highlight"&gt;&lt;pre tabindex="0" class="chroma"&gt;&lt;code class="language-csharp" data-lang="csharp"&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;&lt;span class="n"&gt;dotnet&lt;/span&gt; &lt;span class="k"&gt;add&lt;/span&gt; &lt;span class="n"&gt;package&lt;/span&gt; &lt;span class="n"&gt;Microsoft&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="n"&gt;Agents&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="n"&gt;AI&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="n"&gt;Workflows&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="n"&gt;DurableTask&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/div&gt;&lt;p&gt;Els mateixos executors, el mateix graf de flux de treball — respaldats per estat durador.&lt;/p&gt;
&lt;h2 id="allotjament-a-azure-functions"&gt;Allotjament a Azure Functions&lt;/h2&gt;
&lt;p&gt;La tercera capa és l&amp;rsquo;allotjament a Azure Functions. El vostre flux de treball es converteix en una aplicació Function: activeu el flux de treball via un endpoint HTTP, i el runtime durador gestiona l&amp;rsquo;escalat, l&amp;rsquo;estat i la fiabilitat.&lt;/p&gt;
&lt;p&gt;Això significa que un flux de treball multi-agent amb crides paral·leles, branques condicionals i aprovacions humanes pot escalar en un entorn Functions sense servidor sense gestió d&amp;rsquo;estat personalitzada.&lt;/p&gt;
&lt;h2 id="per-qué-importa-això"&gt;Per Qué Importa Això&lt;/h2&gt;
&lt;p&gt;La combinació és significant per als sistemes d&amp;rsquo;IA reals:&lt;/p&gt;
&lt;ul&gt;
&lt;li&gt;&lt;strong&gt;Crides d&amp;rsquo;agent en paral·lel&lt;/strong&gt; — distribuir a múltiples agents especialitzats simultàniament sense blocatge, agregar resultats quan tots completin&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;Processos de llarga durada&lt;/strong&gt; — els fluxos de treball que impliquen aprovació humana o esdeveniments externs poden pausar i reprendre durant hores o dies&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;Escalat&lt;/strong&gt; — Azure Functions escala l&amp;rsquo;execució horitzontalment; el framework Durable Task gestiona la coordinació de l&amp;rsquo;estat paral·lel&lt;/li&gt;
&lt;/ul&gt;
&lt;p&gt;Si esteu construint fluxos de treball MAF més enllà de demostracions locals simples, aquest és el camí cap a l&amp;rsquo;execució de qualitat producció.&lt;/p&gt;
&lt;p&gt;Publicació original: &lt;a href="https://devblogs.microsoft.com/dotnet/durable-workflows-in-microsoft-agent-framework/"&gt;Durable Workflows in the Microsoft Agent Framework&lt;/a&gt;&lt;/p&gt;</content:encoded></item></channel></rss>