<?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>Orchestration | The .NET Blog</title><link>https://thedotnetblog.com/hi/tags/orchestration/</link><description>Articles, tutorials and insights from the .NET community.</description><generator>Hugo</generator><language>hi</language><managingEditor>@thedotnetblog (The .NET Blog)</managingEditor><webMaster>@thedotnetblog</webMaster><lastBuildDate>Mon, 01 Jun 2026 00:00:00 +0000</lastBuildDate><atom:link href="https://thedotnetblog.com/hi/tags/orchestration/index.xml" rel="self" type="application/rss+xml"/><item><title>हैंडऑफ पैटर्न: जब एक एजेंट काफी नहीं होता</title><link>https://thedotnetblog.com/hi/news/emiliano-montesdeoca/maf-handoff-orchestration-pattern-tour/</link><pubDate>Mon, 01 Jun 2026 00:00:00 +0000</pubDate><author>Emiliano Montesdeoca</author><guid>https://thedotnetblog.com/hi/news/emiliano-montesdeoca/maf-handoff-orchestration-pattern-tour/</guid><description>Microsoft Agent Framework का Handoff ऑर्केस्ट्रेशन पैटर्न एजेंट्स को यह तय करने देता है कि अगला टर्न कौन संभालेगा — बिना बातचीत का संदर्भ खोए या टोपोलॉजी नियमों को तोड़े।</description><content:encoded>&lt;p&gt;किसी न किसी बिंदु पर, हर मल्टी-एजेंट सिस्टम एक साधारण राउटर से आगे निकल जाता है। पहला संकेत आमतौर पर तब होता है जब किसी विशेषज्ञ एजेंट को फॉलो-अप प्रश्न पूछना होता है, या टर्न के बीच में यह महसूस होता है कि किसी अन्य एजेंट को जारी रखना चाहिए। वहाँ फिक्स्ड पाइपलाइन विफल होती है। वन-शॉट राउटर वहाँ विफल होता है।&lt;/p&gt;
&lt;p&gt;यही वह समस्या है जिसे Microsoft Agent Framework में Handoff ऑर्केस्ट्रेशन पैटर्न हल करने के लिए डिज़ाइन किया गया है।&lt;/p&gt;
&lt;h2 id="handoff-कस-कम-करत-ह"&gt;Handoff कैसे काम करता है&lt;/h2&gt;
&lt;p&gt;डेवलपर एक ग्राफ घोषित करता है: ये एजेंट हैं, ये उनके बीच के एज हैं। फ्रेमवर्क बाकी काम करता है — प्रत्येक आउटगोइंग एज के लिए एक हैंडऑफ टूल बनाता है और प्रत्येक एजेंट में इंजेक्ट करता है। जब कोई एजेंट नियंत्रण सौंपने का फैसला करता है, तो वह टूल को कॉल करता है। फ्रेमवर्क टोपोलॉजी को लागू करता है।&lt;/p&gt;
&lt;p&gt;तीन चीजें इसे एजेंट्स के एक-दूसरे को कॉल करने से अलग बनाती हैं:&lt;/p&gt;
&lt;ol&gt;
&lt;li&gt;&lt;strong&gt;एक साझा ट्रांसक्रिप्ट&lt;/strong&gt; — प्राप्त करने वाला एजेंट पूरी बातचीत का इतिहास देखता है। शुरू से शुरू किए बिना।&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;टोपोलॉजी प्रवर्तन&lt;/strong&gt; — एजेंट केवल घोषित लक्ष्यों को हैंडऑफ कर सकता है। रूटिंग बग ऑथरिंग के समय पकड़े जाते हैं, प्रोडक्शन में नहीं।&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;प्राकृतिक समाप्ति&lt;/strong&gt; — जब सक्रिय एजेंट हैंडऑफ टूल को कॉल किए बिना अपना टर्न समाप्त करता है, तो वर्कफ्लो उपयोगकर्ता को सौंप देता है। कोई पोलिंग नहीं, कोई स्पष्ट एग्जिट शर्त नहीं।&lt;/li&gt;
&lt;/ol&gt;
&lt;h2 id="एक-नयनतम-उदहरण"&gt;एक न्यूनतम उदाहरण&lt;/h2&gt;
&lt;p&gt;.NET में, हैंडऑफ वर्कफ्लो बनाना ऐसा दिखता है:&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&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="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="n"&gt;AIAgent&lt;/span&gt; &lt;span class="n"&gt;triage&lt;/span&gt; &lt;span class="p"&gt;=&lt;/span&gt; &lt;span class="n"&gt;chatClient&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="n"&gt;AsAIAgent&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;instructions&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="s"&gt;&amp;#34;Route to the right specialist.&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="n"&gt;name&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="s"&gt;&amp;#34;Triage&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&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;&lt;span class="n"&gt;AIAgent&lt;/span&gt; &lt;span class="n"&gt;billing&lt;/span&gt; &lt;span class="p"&gt;=&lt;/span&gt; &lt;span class="n"&gt;chatClient&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="n"&gt;AsAIAgent&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;instructions&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="s"&gt;&amp;#34;Handle billing questions.&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="n"&gt;name&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="s"&gt;&amp;#34;Billing&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&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;&lt;span class="n"&gt;AIAgent&lt;/span&gt; &lt;span class="n"&gt;tech&lt;/span&gt; &lt;span class="p"&gt;=&lt;/span&gt; &lt;span class="n"&gt;chatClient&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="n"&gt;AsAIAgent&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;instructions&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="s"&gt;&amp;#34;Handle technical support.&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="n"&gt;name&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="s"&gt;&amp;#34;Tech&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&gt;&lt;/span&gt;&lt;span class="line"&gt;&lt;span class="cl"&gt;&lt;span class="kt"&gt;var&lt;/span&gt; &lt;span class="n"&gt;workflow&lt;/span&gt; &lt;span class="p"&gt;=&lt;/span&gt; &lt;span class="n"&gt;HandoffWorkflow&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="n"&gt;Create&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;Add&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="n"&gt;triage&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="n"&gt;targets&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="p"&gt;[&lt;/span&gt;&lt;span class="n"&gt;billing&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="n"&gt;tech&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;Add&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="n"&gt;billing&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="n"&gt;targets&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="p"&gt;[&lt;/span&gt;&lt;span class="n"&gt;triage&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;Add&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="n"&gt;tech&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="n"&gt;targets&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="p"&gt;[&lt;/span&gt;&lt;span class="n"&gt;triage&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="n"&gt;billing&lt;/span&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;Triage किसी भी विशेषज्ञ को भेज सकता है। दोनों विशेषज्ञ triage को वापस भेज सकते हैं। ग्राफ एसाइक्लिक के अनुकूल है लेकिन जरूरत पड़ने पर बैक-एज का समर्थन करता है (&amp;ldquo;मुझे अधिक जानकारी चाहिए&amp;rdquo; → रिसर्च पर वापस)।&lt;/p&gt;
&lt;h2 id="handoff-क-उपयग-कब-कर-और-कब-नह"&gt;Handoff का उपयोग कब करें (और कब नहीं)&lt;/h2&gt;
&lt;p&gt;Handoff एक अच्छा विकल्प है जब:&lt;/p&gt;
&lt;ul&gt;
&lt;li&gt;&lt;strong&gt;बातचीत के बीच में स्वामित्व बदल सकता है&lt;/strong&gt; — एजेंट को एहसास हो सकता है कि वह गलत विशेषज्ञ है&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;बैक-एज महत्वपूर्ण हैं&lt;/strong&gt; — रिस्टार्ट के बिना पिछले चरण पर वापस जाने की जरूरत हो सकती है&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;रूटिंग निर्णय सूक्ष्म हैं&lt;/strong&gt; — हैंडऑफ करने का निर्णय प्रासंगिक है और टाइप्ड प्रेडिकेट के बजाय मॉडल द्वारा बेहतर लिया जाता है&lt;/li&gt;
&lt;/ul&gt;
&lt;p&gt;यह &lt;em&gt;सही&lt;/em&gt; विकल्प नहीं है जब:&lt;/p&gt;
&lt;ul&gt;
&lt;li&gt;आपकी पाइपलाइन फिक्स्ड और सीक्वेंशियल है — उसके लिए &lt;code&gt;Sequential&lt;/code&gt; वर्कफ्लो का उपयोग करें&lt;/li&gt;
&lt;li&gt;प्रत्येक चरण स्वतंत्र है — एजेंट एक ट्रांसक्रिप्ट साझा कर रहे हैं जहां केवल एक को इसकी जरूरत थी, वह सिर्फ शोर है&lt;/li&gt;
&lt;li&gt;आपको कड़े प्रोसेसिंग गारंटी की जरूरत है — मॉडल-चालित रूटिंग का अनिर्धारणवाद वह नहीं है जो आप चाहते हैं&lt;/li&gt;
&lt;/ul&gt;
&lt;h2 id="बक-एज-और-human-in-the-loop"&gt;बैक-एज और Human-in-the-Loop&lt;/h2&gt;
&lt;p&gt;Handoff जो सबसे दिलचस्प रूप सक्षम करता है उनमें से एक असली बैक-एज है। एजेंट तय कर सकता है &amp;ldquo;मेरे पास पर्याप्त जानकारी नहीं है&amp;rdquo; और एक रिसर्च चरण पर वापस रूट कर सकता है — हार्डकोडेड लूप के साथ नहीं, बल्कि इसलिए कि मॉडल तय करता है कि यह सही निर्णय है।&lt;/p&gt;
&lt;p&gt;Human-in-the-loop इंटरैक्शन भी स्वाभाविक रूप से कंपोज होती हैं। जब किसी विशेषज्ञ को उपयोगकर्ता इनपुट की जरूरत होती है, तो वर्कफ्लो डिफ़ॉल्ट टर्न लूप के माध्यम से उपयोगकर्ता को सौंप देता है, प्रतिक्रिया एकत्र करता है, और पूर्ण संदर्भ के साथ फिर से शुरू होता है। एजेंट ने कभी बातचीत नहीं खोई।&lt;/p&gt;
&lt;h2 id="नषकरष"&gt;निष्कर्ष&lt;/h2&gt;
&lt;p&gt;Handoff उन पैटर्न में से एक है जो सरल लगता है लेकिन एक बार आंतरिक होने के बाद बहुत कुछ सक्षम करता है: विकेंद्रीकृत रूटिंग, साझा संदर्भ, लागू टोपोलॉजी, प्राकृतिक समाप्ति। यह सही अगला कदम है जब आपके एजेंट &amp;ldquo;वास्तव में, किसी और को इसे संभालना चाहिए&amp;rdquo; कहना शुरू करते हैं।&lt;/p&gt;
&lt;p&gt;मूल पोस्ट में पूरा वॉकथ्रू पढ़ें: &lt;a href="https://devblogs.microsoft.com/agent-framework/a-tour-of-handoff-orchestration-pattern/"&gt;A Tour of the Handoff Orchestration Pattern&lt;/a&gt;&lt;/p&gt;</content:encoded></item></channel></rss>