{"id":10057,"date":"2023-12-12T11:41:25","date_gmt":"2023-12-12T14:41:25","guid":{"rendered":"https:\/\/elemarjr.com\/clube-de-estudos\/?post_type=artigos&#038;p=10057"},"modified":"2023-12-26T09:51:36","modified_gmt":"2023-12-26T12:51:36","slug":"o-retry-pattern-e-o-tratamento-correto-de-indisponibilidades","status":"publish","type":"artigos","link":"https:\/\/elemarjr.com\/clube-de-estudos\/artigos\/o-retry-pattern-e-o-tratamento-correto-de-indisponibilidades\/","title":{"rendered":"O Retry Pattern e o Tratamento Correto de Indisponibilidades"},"content":{"rendered":"\n<p>A import\u00e2ncia da resili\u00eancia em sistemas de software \u00e9 incontest\u00e1vel, especialmente quando falamos de intera\u00e7\u00f5es com outros servi\u00e7os. A confiabilidade de um software depende n\u00e3o apenas do c\u00f3digo interno, mas tamb\u00e9m da capacidade de lidar com fatores externos, como falhas de servi\u00e7os terceiros. O <em>retry pattern<\/em> surge como uma resposta estrat\u00e9gica a essas intermit\u00eancias.<\/p>\n\n\n\n<h2 class=\"wp-block-heading\">O Que \u00c9 o Retry Pattern?<\/h2>\n\n\n\n<p>O <em>retry pattern<\/em> \u00e9 um padr\u00e3o utilizado no design de software que permite a um sistema tentar repetidamente executar uma opera\u00e7\u00e3o falha antes de consider\u00e1-la um erro permanente. Esse padr\u00e3o \u00e9 um reconhecimento de que falhas em aplica\u00e7\u00f5es distribu\u00eddas s\u00e3o muitas vezes transit\u00f3rias.<\/p>\n\n\n\n<h2 class=\"wp-block-heading\">A Aplica\u00e7\u00e3o Cr\u00edtica do Retry Pattern<\/h2>\n\n\n\n<p>A implementa\u00e7\u00e3o do <em>retry pattern<\/em> envolve definir uma pol\u00edtica de retentativas, especificando o n\u00famero de vezes que uma opera\u00e7\u00e3o deve ser refeita, o intervalo entre essas tentativas, e um poss\u00edvel incremento desse intervalo ap\u00f3s falhas consecutivas, t\u00e9cnica chamada de <em>backoff<\/em>. Uma implementa\u00e7\u00e3o efetiva deste padr\u00e3o ajuda a manter a integridade do sistema, mesmo quando servi\u00e7os externos est\u00e3o temporariamente indispon\u00edveis.<\/p>\n\n\n\n<h2 class=\"wp-block-heading\">Exemplos e Estrat\u00e9gias Avan\u00e7adas<\/h2>\n\n\n\n<p>Um exemplo avan\u00e7ado poderia incluir uma estrat\u00e9gia de <em>backoff exponencial<\/em> com <em>jitter<\/em>, que \u00e9 uma varia\u00e7\u00e3o aleat\u00f3ria no tempo de espera entre retentativas para evitar sobrecarga em sistemas sincronizados:<\/p>\n\n\n\n<div class=\"wp-block-kevinbatdorf-code-block-pro\" style=\"font-size:.875rem;line-height:1.25rem\"><span style=\"display:block;padding:16px 0 0 16px;margin-bottom:-1px;width:100%;text-align:left;background-color:#2e3440ff\"><svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"54\" height=\"14\" viewBox=\"0 0 54 14\"><g fill=\"none\" fill-rule=\"evenodd\" transform=\"translate(1 1)\"><circle cx=\"6\" cy=\"6\" r=\"6\" fill=\"#FF5F56\" stroke=\"#E0443E\" stroke-width=\".5\"><\/circle><circle cx=\"26\" cy=\"6\" r=\"6\" fill=\"#FFBD2E\" stroke=\"#DEA123\" stroke-width=\".5\"><\/circle><circle cx=\"46\" cy=\"6\" r=\"6\" fill=\"#27C93F\" stroke=\"#1AAB29\" stroke-width=\".5\"><\/circle><\/g><\/svg><\/span><span role=\"button\" tabindex=\"0\" data-code=\"\/\/ Exemplo de backoff exponencial com jitter em C# usando Polly\nvar retryPolicy = Policy\n    .Handle<SomeTransientException&gt;()\n    .WaitAndRetryAsync(5, \n        retryAttempt =&gt; TimeSpan.FromSeconds(Math.Pow(2, retryAttempt)) \n                        + TimeSpan.FromMilliseconds(new Random().Next(0, 1000)),\n        onRetry: (exception, timeSpan, retryCount, context) =&gt;\n        {\n            \/\/ Logica adicional a cada retentativa\n        });\n\nawait retryPolicy.ExecuteAsync(() =&gt; SomeExternalCall());\" style=\"color:#d8dee9ff;display:none\" aria-label=\"Copy\" class=\"code-block-pro-copy-button\"><svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" style=\"width:24px;height:24px\" fill=\"none\" viewBox=\"0 0 24 24\" stroke=\"currentColor\" stroke-width=\"2\"><path class=\"with-check\" stroke-linecap=\"round\" stroke-linejoin=\"round\" d=\"M9 5H7a2 2 0 00-2 2v12a2 2 0 002 2h10a2 2 0 002-2V7a2 2 0 00-2-2h-2M9 5a2 2 0 002 2h2a2 2 0 002-2M9 5a2 2 0 012-2h2a2 2 0 012 2m-6 9l2 2 4-4\"><\/path><path class=\"without-check\" stroke-linecap=\"round\" stroke-linejoin=\"round\" d=\"M9 5H7a2 2 0 00-2 2v12a2 2 0 002 2h10a2 2 0 002-2V7a2 2 0 00-2-2h-2M9 5a2 2 0 002 2h2a2 2 0 002-2M9 5a2 2 0 012-2h2a2 2 0 012 2\"><\/path><\/svg><\/span><pre class=\"shiki nord\" style=\"background-color: #2e3440ff\"><code><span class=\"line\"><span style=\"color: #616E88\">\/\/ Exemplo de backoff exponencial com jitter em C# usando Polly<\/span><\/span>\n<span class=\"line\"><span style=\"color: #81A1C1\">var<\/span><span style=\"color: #D8DEE9FF\"> retryPolicy <\/span><span style=\"color: #81A1C1\">=<\/span><span style=\"color: #D8DEE9FF\"> <\/span><span style=\"color: #D8DEE9\">Policy<\/span><\/span>\n<span class=\"line\"><span style=\"color: #D8DEE9FF\">    <\/span><span style=\"color: #ECEFF4\">.<\/span><span style=\"color: #88C0D0\">Handle<\/span><span style=\"color: #ECEFF4\">&lt;<\/span><span style=\"color: #D8DEE9FF\">SomeTransientException<\/span><span style=\"color: #ECEFF4\">&gt;()<\/span><\/span>\n<span class=\"line\"><span style=\"color: #D8DEE9FF\">    <\/span><span style=\"color: #ECEFF4\">.<\/span><span style=\"color: #88C0D0\">WaitAndRetryAsync<\/span><span style=\"color: #ECEFF4\">(<\/span><span style=\"color: #B48EAD\">5<\/span><span style=\"color: #ECEFF4\">,<\/span><span style=\"color: #D8DEE9FF\"> <\/span><\/span>\n<span class=\"line\"><span style=\"color: #D8DEE9FF\">        retryAttempt <\/span><span style=\"color: #81A1C1\">=&gt;<\/span><span style=\"color: #D8DEE9FF\"> <\/span><span style=\"color: #D8DEE9\">TimeSpan<\/span><span style=\"color: #ECEFF4\">.<\/span><span style=\"color: #88C0D0\">FromSeconds<\/span><span style=\"color: #ECEFF4\">(<\/span><span style=\"color: #D8DEE9\">Math<\/span><span style=\"color: #ECEFF4\">.<\/span><span style=\"color: #88C0D0\">Pow<\/span><span style=\"color: #ECEFF4\">(<\/span><span style=\"color: #B48EAD\">2<\/span><span style=\"color: #ECEFF4\">,<\/span><span style=\"color: #D8DEE9FF\"> <\/span><span style=\"color: #D8DEE9\">retryAttempt<\/span><span style=\"color: #ECEFF4\">))<\/span><span style=\"color: #D8DEE9FF\"> <\/span><\/span>\n<span class=\"line\"><span style=\"color: #D8DEE9FF\">                        <\/span><span style=\"color: #81A1C1\">+<\/span><span style=\"color: #D8DEE9FF\"> <\/span><span style=\"color: #D8DEE9\">TimeSpan<\/span><span style=\"color: #ECEFF4\">.<\/span><span style=\"color: #88C0D0\">FromMilliseconds<\/span><span style=\"color: #ECEFF4\">(<\/span><span style=\"color: #81A1C1\">new<\/span><span style=\"color: #D8DEE9FF\"> Random<\/span><span style=\"color: #ECEFF4\">().<\/span><span style=\"color: #88C0D0\">Next<\/span><span style=\"color: #ECEFF4\">(<\/span><span style=\"color: #B48EAD\">0<\/span><span style=\"color: #ECEFF4\">,<\/span><span style=\"color: #D8DEE9FF\"> <\/span><span style=\"color: #B48EAD\">1000<\/span><span style=\"color: #ECEFF4\">)),<\/span><\/span>\n<span class=\"line\"><span style=\"color: #D8DEE9FF\">        onRetry<\/span><span style=\"color: #ECEFF4\">:<\/span><span style=\"color: #D8DEE9FF\"> <\/span><span style=\"color: #ECEFF4\">(<\/span><span style=\"color: #D8DEE9FF\">exception<\/span><span style=\"color: #ECEFF4\">,<\/span><span style=\"color: #D8DEE9FF\"> timeSpan<\/span><span style=\"color: #ECEFF4\">,<\/span><span style=\"color: #D8DEE9FF\"> retryCount<\/span><span style=\"color: #ECEFF4\">,<\/span><span style=\"color: #D8DEE9FF\"> context<\/span><span style=\"color: #ECEFF4\">)<\/span><span style=\"color: #D8DEE9FF\"> <\/span><span style=\"color: #81A1C1\">=&gt;<\/span><\/span>\n<span class=\"line\"><span style=\"color: #D8DEE9FF\">        <\/span><span style=\"color: #ECEFF4\">{<\/span><\/span>\n<span class=\"line\"><span style=\"color: #ECEFF4\">            <\/span><span style=\"color: #616E88\">\/\/ Logica adicional a cada retentativa<\/span><\/span>\n<span class=\"line\"><span style=\"color: #D8DEE9FF\">        <\/span><span style=\"color: #ECEFF4\">})<\/span><span style=\"color: #81A1C1\">;<\/span><\/span>\n<span class=\"line\"><\/span>\n<span class=\"line\"><span style=\"color: #D8DEE9FF\">await retryPolicy<\/span><span style=\"color: #ECEFF4\">.<\/span><span style=\"color: #88C0D0\">ExecuteAsync<\/span><span style=\"color: #ECEFF4\">(<\/span><span style=\"color: #D8DEE9FF\">(<\/span><span style=\"color: #ECEFF4\">)<\/span><span style=\"color: #D8DEE9FF\"> <\/span><span style=\"color: #81A1C1\">=&gt;<\/span><span style=\"color: #D8DEE9FF\"> <\/span><span style=\"color: #88C0D0\">SomeExternalCall<\/span><span style=\"color: #ECEFF4\">()<\/span><span style=\"color: #D8DEE9FF\">)<\/span><span style=\"color: #81A1C1\">;<\/span><\/span><\/code><\/pre><\/div>\n\n\n\n<p>Essa pol\u00edtica de retentativa aumenta o tempo de espera exponencialmente a cada falha e adiciona um pequeno <em>jitter<\/em>. Isso n\u00e3o apenas distribui as retentativas ao longo do tempo, mas tamb\u00e9m reduz a probabilidade de colis\u00e3o entre m\u00faltiplas inst\u00e2ncias do servi\u00e7o tentando a opera\u00e7\u00e3o simultaneamente.<\/p>\n\n\n\n<h2 class=\"wp-block-heading\">Conclus\u00e3o<\/h2>\n\n\n\n<p>Integrar o <em>retry pattern<\/em> na arquitetura do seu sistema \u00e9 essencial para garantir a resili\u00eancia e a confiabilidade, especialmente em um ecossistema com servi\u00e7os dependentes. A correta aplica\u00e7\u00e3o deste padr\u00e3o pode ser a diferen\u00e7a entre um sistema confi\u00e1vel e um que falha sob condi\u00e7\u00f5es adversas. Adicionalmente, conhecer e aplicar estrat\u00e9gias como o <em>backoff exponencial<\/em> e o <em>jitter<\/em> s\u00e3o vitais para uma implementa\u00e7\u00e3o de retentativas eficiente.<\/p>\n\n\n\n<p>No \u00e2mbito dos meus grupos de estudos e mentorias, aprofundamos na aplica\u00e7\u00e3o deste e de outros padr\u00f5es relevantes para a cria\u00e7\u00e3o de sistemas altamente dispon\u00edveis e robustos. Discutimos tamb\u00e9m a intera\u00e7\u00e3o entre o <em>retry pattern<\/em> e padr\u00f5es complementares, como o <em>Circuit Breaker<\/em>, para criar uma arquitetura coesa e resistente a falhas.<\/p>\n\n\n\n<h2 class=\"wp-block-heading\">TL;DR<\/h2>\n\n\n\n<ol class=\"wp-block-list\">\n<li>O <em>retry pattern<\/em> proporciona uma forma de lidar com falhas tempor\u00e1rias e \u00e9 fundamental em sistemas que interagem com servi\u00e7os externos.<\/li>\n\n\n\n<li>Aplicar t\u00e9cnicas avan\u00e7adas como <em>backoff exponencial<\/em> e <em>jitter<\/em> ajuda a evitar a sobrecarga nos sistemas.<\/li>\n\n\n\n<li>A compreens\u00e3o e aplica\u00e7\u00e3o correta do <em>retry pattern<\/em> \u00e9 regularmente aprofundada em grupos de estudos e mentorias para a constru\u00e7\u00e3o de sistemas robustos e confi\u00e1veis.<\/li>\n<\/ol>\n","protected":false},"featured_media":10044,"parent":0,"template":"","cursos":[7],"class_list":["post-10057","artigos","type-artigos","status-publish","has-post-thumbnail","hentry","cursos-gof"],"acf":[],"_links":{"self":[{"href":"https:\/\/elemarjr.com\/clube-de-estudos\/wp-json\/wp\/v2\/artigos\/10057","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/elemarjr.com\/clube-de-estudos\/wp-json\/wp\/v2\/artigos"}],"about":[{"href":"https:\/\/elemarjr.com\/clube-de-estudos\/wp-json\/wp\/v2\/types\/artigos"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/elemarjr.com\/clube-de-estudos\/wp-json\/wp\/v2\/media\/10044"}],"wp:attachment":[{"href":"https:\/\/elemarjr.com\/clube-de-estudos\/wp-json\/wp\/v2\/media?parent=10057"}],"wp:term":[{"taxonomy":"cursos","embeddable":true,"href":"https:\/\/elemarjr.com\/clube-de-estudos\/wp-json\/wp\/v2\/cursos?post=10057"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}