<?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/id/tags/durable-task/</link><description>Articles, tutorials and insights from the .NET community.</description><generator>Hugo</generator><language>id</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/id/tags/durable-task/index.xml" rel="self" type="application/rss+xml"/><item><title>Alur Kerja yang Tahan Lama di Microsoft Agent Framework: Dari In-Memory ke Azure Functions</title><link>https://thedotnetblog.com/id/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/id/news/emiliano-montesdeoca/maf-durable-workflows-azure-functions-durable-task/</guid><description>Model pemrograman alur kerja MAF kini mendukung eksekusi tahan lama yang didukung oleh Durable Task — berikut cara membangun alur kerja agen yang dapat dikomposisi yang bertahan dari restart proses dan diskalakan di Azure Functions.</description><content:encoded>&lt;p&gt;Salah satu titik nyeri dengan alur kerja agen AI awal: mereka rapuh. Alur kerja multi-langkah yang berjalan lama dan terikat pada satu proses berarti restart proses = status hilang. Untuk demo sederhana ini tidak masalah. Untuk beban kerja produksi tidak.&lt;/p&gt;
&lt;p&gt;Model pemrograman alur kerja Microsoft Agent Framework kini mendukung &lt;strong&gt;eksekusi tahan lama&lt;/strong&gt;, didukung oleh framework Durable Task, dengan hosting Azure Functions. Berikut cara kerja model pemrograman dan mengapa cerita ketahanan itu penting.&lt;/p&gt;
&lt;h2 id="blok-pembangun-inti"&gt;Blok Pembangun Inti&lt;/h2&gt;
&lt;p&gt;&lt;strong&gt;Executor&lt;/strong&gt; adalah unit kerja yang mendasar. Setiap executor memiliki tipe — menerima input tertentu dan menghasilkan output tertentu:&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;// cari pesanan, kembalikan&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;&lt;strong&gt;Workflow&lt;/strong&gt; menghubungkan executor ke dalam grafik terarah menggunakan fluent builder. Framework menangani eksekusi, aliran data antar langkah, dan propagasi kesalahan.&lt;/p&gt;
&lt;p&gt;Anda dapat memodelkan:&lt;/p&gt;
&lt;ul&gt;
&lt;li&gt;Rantai sekuensial (langkah A → langkah B → langkah C)&lt;/li&gt;
&lt;li&gt;Fan-out/fan-in paralel (jalankan agen A, B, C secara paralel, agregasi hasil)&lt;/li&gt;
&lt;li&gt;Percabangan kondisional&lt;/li&gt;
&lt;li&gt;Persetujuan human-in-the-loop (jeda alur kerja, tunggu sinyal eksternal)&lt;/li&gt;
&lt;/ul&gt;
&lt;h2 id="runner-in-memory-untuk-pengembangan-lokal"&gt;Runner In-Memory untuk Pengembangan Lokal&lt;/h2&gt;
&lt;p&gt;Memulai itu cepat:&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;Paket inti mencakup runner in-process yang ringan. Tidak ada dependensi eksternal, tidak ada database, tidak ada sumber daya Azure. Bekerja sangat baik untuk pengembangan lokal dan pengujian unit.&lt;/p&gt;
&lt;h2 id="menambahkan-ketahanan-dengan-durable-task"&gt;Menambahkan Ketahanan dengan Durable Task&lt;/h2&gt;
&lt;p&gt;Ketika alur kerja perlu bertahan dari restart proses — karena berjalan lama, karena memiliki langkah human-in-the-loop, karena tersebar di banyak panggilan agen paralel — runner in-memory tidak cukup.&lt;/p&gt;
&lt;p&gt;Integrasi Durable Task MAF menyimpan status alur kerja di Azure Storage. Jika proses dimulai ulang, alur kerja dilanjutkan dari tempat berhenti. Model pemrograman tetap sama; Anda hanya mengganti 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;Executor yang sama, grafik alur kerja yang sama — didukung oleh status tahan lama.&lt;/p&gt;
&lt;h2 id="hosting-azure-functions"&gt;Hosting Azure Functions&lt;/h2&gt;
&lt;p&gt;Lapisan ketiga adalah hosting Azure Functions. Alur kerja Anda menjadi aplikasi Function: picu alur kerja melalui endpoint HTTP, dan runtime tahan lama menangani penskalaan, status, dan keandalan.&lt;/p&gt;
&lt;p&gt;Ini berarti alur kerja multi-agen dengan panggilan paralel, percabangan kondisional, dan persetujuan manusia dapat diskalakan di seluruh lingkungan Functions serverless tanpa manajemen status kustom.&lt;/p&gt;
&lt;h2 id="mengapa-ini-penting"&gt;Mengapa Ini Penting&lt;/h2&gt;
&lt;p&gt;Kombinasi ini signifikan untuk sistem AI nyata:&lt;/p&gt;
&lt;ul&gt;
&lt;li&gt;&lt;strong&gt;Panggilan agen paralel&lt;/strong&gt; — distribusikan ke beberapa agen khusus secara bersamaan tanpa memblokir, agregasi hasil saat semua selesai&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;Proses yang berjalan lama&lt;/strong&gt; — alur kerja yang melibatkan persetujuan manusia atau peristiwa eksternal dapat menjeda dan melanjutkan selama berjam-jam atau berhari-hari&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;Penskalaan&lt;/strong&gt; — Azure Functions menskalakan eksekusi secara horizontal; framework Durable Task mengelola koordinasi status paralel&lt;/li&gt;
&lt;/ul&gt;
&lt;p&gt;Jika Anda membangun alur kerja MAF di luar demo lokal sederhana, ini adalah jalan menuju eksekusi berkualitas produksi.&lt;/p&gt;
&lt;p&gt;Posting asli: &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>