<?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>Service Bus | The .NET Blog</title><link>https://thedotnetblog.com/hi/tags/service-bus/</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>Thu, 21 May 2026 00:00:00 +0000</lastBuildDate><atom:link href="https://thedotnetblog.com/hi/tags/service-bus/index.xml" rel="self" type="application/rss+xml"/><item><title>संघर्षरत निर्भरता को लगातार प्रहार करना बंद करें: Azure Functions + Service Bus के लिए रिट्री पैटर्न</title><link>https://thedotnetblog.com/hi/news/emiliano-montesdeoca/azure-functions-service-bus-exponential-backoff-circuit-breaker/</link><pubDate>Thu, 21 May 2026 00:00:00 +0000</pubDate><author>Emiliano Montesdeoca</author><guid>https://thedotnetblog.com/hi/news/emiliano-montesdeoca/azure-functions-service-bus-exponential-backoff-circuit-breaker/</guid><description>एक्सपोनेंशियल बैकऑफ और सर्किट ब्रेकर पैटर्न अब Service Bus-ट्रिगर्ड Azure Functions के लिए नेटिव रूप से समर्थित हैं — यहां बताया गया है कि ये कैसे काम करते हैं और आपको दोनों क्यों चाहिए।</description><content:encoded>&lt;p&gt;यहां बताया गया है कि Functions ऐप में एक पुनर्प्राप्य दोष आउटेज कैसे बन जाता है: एक निर्भरता टाइमआउट होने लगती है, हर Functions इंस्टेंस तुरंत और अनिश्चित काल के लिए रिट्राई करता है, निर्भरता को सैकड़ों समवर्ती विफल अनुरोधों से हमला किया जाता है, और जो एक क्षणिक हिचकी के रूप में शुरू हुआ वह एक सिस्टम-व्यापी बैकप्रेशर इवेंट बन जाता है।&lt;/p&gt;
&lt;p&gt;आप शायद यह कहानी जानते हैं। Azure Functions तेजी से स्केल आउट होती है — यही पूरा उद्देश्य है। लेकिन &amp;ldquo;तेजी से स्केल आउट&amp;rdquo; और &amp;ldquo;तुरंत रिट्राई&amp;rdquo; एक साथ विफलताओं को नाटकीय रूप से बदतर बना सकते हैं।&lt;/p&gt;
&lt;p&gt;दो पैटर्न मदद करते हैं। एक्सपोनेंशियल बैकऑफ और सर्किट ब्रेकर। दोनों अब Service Bus-ट्रिगर्ड Azure Functions के लिए नेटिव रूप से समर्थित हैं।&lt;/p&gt;
&lt;h2 id="द-पटरन-अलग-अलग-भमकए"&gt;दो पैटर्न, अलग-अलग भूमिकाएं&lt;/h2&gt;
&lt;p&gt;ये पैटर्न पूरक हैं, विकल्प नहीं:&lt;/p&gt;
&lt;p&gt;&lt;strong&gt;एक्सपोनेंशियल बैकऑफ&lt;/strong&gt; जवाब देता है: &lt;em&gt;मुझे कब दोबारा प्रयास करना चाहिए?&lt;/em&gt;
यह रिट्राई के बीच देरी बढ़ाता है ताकि एक निर्भरता को ठीक होने का समय मिले। संदेश स्तर पर, रिट्राई टाइमिंग को गति देना।&lt;/p&gt;
&lt;p&gt;&lt;strong&gt;सर्किट ब्रेकर&lt;/strong&gt; जवाब देता है: &lt;em&gt;क्या मुझे अभी इस निर्भरता को कॉल करना चाहिए?&lt;/em&gt;
विफलता सीमा पहुंचने के बाद एक अस्वस्थ निर्भरता पर बार-बार कॉल रोकता है, फिर कूलडाउन अवधि के बाद सावधानी से जांच करता है। सिस्टम स्तर पर, रिट्राई तूफान को रोकना।&lt;/p&gt;
&lt;p&gt;आपको दोनों चाहिए। बैकऑफ प्रति संदेश रिट्राई पेसिंग संभालता है। सर्किट ब्रेकर एग्रीगेट स्वास्थ्य निर्णय संभालता है।&lt;/p&gt;
&lt;h2 id="service-bus-क-लए-यह-वशष-रप-स-कय-महतवपरण-ह"&gt;Service Bus के लिए यह विशेष रूप से क्यों महत्वपूर्ण है&lt;/h2&gt;
&lt;p&gt;कतार बर्स्ट ट्रैफिक को अवशोषित करती है, जो अच्छी बात है। लेकिन नियंत्रण के बिना, कतार बढ़ सकती है जबकि वर्कर उन कॉल पर कम्प्यूट बर्बाद करते रहते हैं जो विफल हो जाएंगे। पॉइजन संदेश उतने समय से अधिक समय तक सक्रिय रहते हैं। हॉट पार्टिशन या सीमित डाउनस्ट्रीम क्षमता कैस्केडिंग समस्याएं पैदा करती है।&lt;/p&gt;
&lt;p&gt;सुरक्षित डिज़ाइन:&lt;/p&gt;
&lt;ol&gt;
&lt;li&gt;क्षणिक विफलता का पता लगाएं&lt;/li&gt;
&lt;li&gt;एक्सपोनेंशियल बैकऑफ के साथ अगला प्रयास विलंबित करें&lt;/li&gt;
&lt;li&gt;विफलता सीमा पहुंचने पर निर्भरता को कॉल करना बंद करें (सर्किट खुला)&lt;/li&gt;
&lt;li&gt;कूलडाउन अवधि के बाद सावधानी से फिर से शुरू करें (सर्किट जांच)&lt;/li&gt;
&lt;li&gt;अप्राप्य कार्य को dead-letter या संगरोध पथ पर ले जाएं&lt;/li&gt;
&lt;/ol&gt;
&lt;h2 id="नटव-समरथन-कस-दखत-ह"&gt;नेटिव समर्थन कैसा दिखता है&lt;/h2&gt;
&lt;p&gt;नया समर्थन मौजूदा Azure Functions होस्ट मॉडल के साथ एकीकृत होता है — कोई अतिरिक्त लाइब्रेरी नहीं, कोई कस्टम कार्यान्वयन नहीं। कॉन्फ़िगरेशन आपके &lt;code&gt;host.json&lt;/code&gt; में जाता है:&lt;/p&gt;
&lt;div class="highlight"&gt;&lt;pre tabindex="0" class="chroma"&gt;&lt;code class="language-json" data-lang="json"&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="nt"&gt;&amp;#34;extensions&amp;#34;&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="nt"&gt;&amp;#34;serviceBus&amp;#34;&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="nt"&gt;&amp;#34;messageHandlerOptions&amp;#34;&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="nt"&gt;&amp;#34;maxRetryCount&amp;#34;&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="mi"&gt;5&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="nt"&gt;&amp;#34;retryPolicy&amp;#34;&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="nt"&gt;&amp;#34;mode&amp;#34;&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="s2"&gt;&amp;#34;exponentialBackoff&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="nt"&gt;&amp;#34;minBackoff&amp;#34;&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="s2"&gt;&amp;#34;00:00:02&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="nt"&gt;&amp;#34;maxBackoff&amp;#34;&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="s2"&gt;&amp;#34;00:05:00&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="nt"&gt;&amp;#34;maxRetryCount&amp;#34;&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="mi"&gt;5&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;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;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;/p&gt;
&lt;h2 id="कवर-क-गई-भषए"&gt;कवर की गई भाषाएं&lt;/h2&gt;
&lt;p&gt;यह केवल .NET के लिए नहीं है। यह सुविधा dotnet, JavaScript, TypeScript और Python को कवर करती है — Azure Functions में Service Bus ट्रिगर द्वारा समर्थित भाषाओं का पूरा सेट।&lt;/p&gt;
&lt;h2 id="नषकरष"&gt;निष्कर्ष&lt;/h2&gt;
&lt;p&gt;रिट्राई पैटर्न तब तक कॉन्फ़िगर करने में रोमांचक नहीं होते जब तक कि पहली बार डाउनस्ट्रीम आउटेज आपकी Functions को समस्या को बेहतर बनाने के बजाय बदतर करने का कारण नहीं बनता। इन्हें सक्रिय रूप से सेट करना सस्ता है। किसी घटना के दौरान इन्हें फिर से तैयार करना नहीं है।&lt;/p&gt;
&lt;p&gt;मूल पोस्ट: &lt;a href="https://devblogs.microsoft.com/azure-sdk/exponential-backoff-circuit-breaker-azure-functions/"&gt;Exponential backoff and circuit breaker for Service Bus-triggered Azure Functions&lt;/a&gt;&lt;/p&gt;</content:encoded></item></channel></rss>