使用.NetCore 控制台演示 熔断 降级(polly)

1、熔断降级的概念: 

    熔断:我这里有一根长度一米的钢铁,钢铁的熔点1000度(假设),现在我想用力把这根钢铁折弯,但是人的力有限达不到折弯的点,然后我使用火给钢铁加热,每隔一段时间我就会尝试一下是否能折弯,在这个过程中我发现,随着不断的煅烧,折弯钢铁是花费的力气越小,在这个过程出现了意外因为我的疏忽,温度超过了钢铁的熔点了,导致一根变成的两根,和我最初的目的相违背了,早知道当初我装个报警的装置了还可以提想我。 

  如果在这个例子中我们把一根钢铁换成我们程序中的接口(接口能同时承受1000的访问),然后把火替换成我们的接口调用者,当接口的并发超过1000这个点的时候接口将会挂掉,作为调用者并不能控制这个点,当并发量上来的时候导致接口蹦了,为了防止我们的接口发生崩溃的情况,我们做一个报警的设置,当发生这个情况的时候占时切断服务,防止服务崩溃。

   降级:接着上一个例子:既然这个钢铁因为一个意外导致变成两个,不能进行使用了,我变找了一个绳子替代一下。 

    当我们的服务接口发生错误的时候,我们可以找到一个替代方法进行使用。这个方法可能是启用另一台服务器的接口,也可能是只返回“”服务器繁忙请重试的提示“”。总之不会把一个系统级别的问题暴露给用户,让使用者的程序也出现问题。

2、Polly的7中策略

 处理熔断降级的框架本人所知 NetFlix的Hystrix框架和Polly框架我们将使用Polly进行熔断降级处理。

    Polly概念Polly是一个被.net基金会支持认可的框架,Polly是一个.NET弹性和瞬态故障处理库,允许开发人员以流畅和线程安全的方式表达策略,如重试、断路器、超时、舱壁隔离和回退

    Polly的7种策略:官方文档是这么说的:

    1、重试(Retry):当程序发生短暂的故障、并且故障在延迟后,可以自动纠正的,前期是暂时的我们可以配置自动重试。

    2、断路器(Circuit-Breaker):当一个系统陷入严重的问题时,让系统快速的失败,比让用户一直等待着要好的多,保护一个系统不受过载的影响,可以帮助它快速的恢复。

    3、超时(Timeout):在等待一定的时间后,没有返回相应的结果,保证程序不会一直等待下去,使调用者不必一直的等待下去。

     4、隔离(Bulkhead Isolation):当进程出现故障的时,一台主机中的多个失败的进程,对资源(例如线程/CPU)的一直占用,当下游的系统发生故障的时候,也可能导致上游对资源的调用失败、这两种风险的出现都将导致更大范围的影响、隔离策略是为了防止“一个点的失败导致整盘的失败”把受到管理的操作固定在某个资源中,避免影响到其他的资源。

    5、缓存(Cache):针对相同的请求,在第一次访问的时候将响应的数据进行缓存,再次访问的时候直接在缓存中提供响应的数据。

    6、回退(FallBack):当程序发生失败的情况的时候,我们将做些什么,定义一个在程序发生失败的时候要执行的动作。

    7、策略组合(PolicyWrap):Polly针对不同的故障有不同的策略,我们可以灵活的组合策略,上述的六种策略可以灵活组合使用。

3、Polly的基本用法

    因为Polly对NetCore的友好支持,下面我们将使用Core的控制台对Polly的几种策略进行简单的演示

    首先创建控制台程序

    640?wx_fmt=png

    Nuget的控制台中使用 Install-Package Polly 命令进行安装

     注意:在创建项目的时候命名尽量不要使用Polly命名

    Polly 每个版本的介绍 https://www.nuget.org/packages/Polly/

    执行命令进行安装如下图所示

    640?wx_fmt=png

    首先我们要学会并且指定希望Policy 处理的异常

640?wx_fmt=png

  下面我们指定一个希望Policy处理的异常,并且完成调用

640?wx_fmt=png

 因为throw new Exception(); HResult 的值为

      如图所示

    640?wx_fmt=png

     执行结果为:

       640?wx_fmt=png

 

     当我们使用throw new ArgumentException();  它的HResult 的值为

    如图所示:

     640?wx_fmt=png

    

    执行结果为

    因为我们没有做任何的处理所以程序直接报错

    640?wx_fmt=png

    上面演示了Policy的基本用法

4、Polly7种策略的使用

    1、重试策略(Retry):

640?wx_fmt=png

 执行结果:

      640?wx_fmt=jpeg

    2、断路器(Circuit-Breaker)

640?wx_fmt=png

 执行结果:

    640?wx_fmt=png

    3、 超时策略(Timeout

640?wx_fmt=png

 执行结果:

      640?wx_fmt=png

    4、隔离策略(Bulkhead Isolation)

640?wx_fmt=png

执行结果:

    640?wx_fmt=png

    5、缓存策略(Cache):

640?wx_fmt=png

6、 回退(FallBack)

640?wx_fmt=png

 执行结果

    640?wx_fmt=png

    7、策略组合(PolicyWrap)

     PolicyWrap的上面六种策略可以任意的组合起来使用:我们将超时策略(Timeout)加上回退(FallBack)策略组合使用

640?wx_fmt=png

行结果:

        640?wx_fmt=png

      OK

      这些只是简单的演示,官方文档更加详细

下一篇我们是使用 Aop 基于 AspNetCore 的过滤器 实现一下Policy 的使用。

原文地址:https://www.cnblogs.com/szlblog/p/9300845.html

.NET社区新闻,深度好文,欢迎访问公众号文章汇总 http://www.csharpkit.com

640?wx_fmt=jpeg

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/320830.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

I Got a Matrix!

I Got a Matrix! 题目大意: 给一个矩阵,求出边上的数的和 原题: 题目描述 给定一个 n ∗ m 的矩阵 A,询问位于矩阵边缘的元素之和。所谓矩阵边缘的元素,就是第一行和 最后一行的元素以及第一列和最后一列的元素。…

jzoj6803-NOIP2020.9.26模拟tom【构造】

正题 题目大意 nnn个点的一棵树,给每个点一个权值是1∼a1\sim a1∼a或−1∼−b-1\sim -b−1∼−b。每次选择正负中一个绝对值最小的删去使得无论如何选择都不会将树分成两个联通块。 解题思路 因为可以随意选择,所以aaa和−b-b−b的点一定要连在一起&am…

给正在努力的您几条建议(附开源代码)

前言我是一名在广州的某家互联网公司工作,并有6年工作经验,奔着架构师与微软MVP为目标的老鸟程序员。最近回顾了下多年来走的路,有不少的弯路。今天不说技术,而是总结了一些职业生涯上的建议与大家分享。虽说今天不说技术&#xf…

BZOJ3527: [Zjoi2014]力 [FFT]

化简之后&#xff0c;发现减号左边的式子是一个卷积。右边的式子&#xff0c;把一个函数倒序就是卷积&#xff0c;分别FFT&#xff0c;求解答案。 大佬blog: https://blog.csdn.net/kyleyoung_ymj/article/details/51721495 #include <bits/stdc.h> #define pi acos(-1.0…

jzoj6804-NOIP2020.9.26模拟jerry【dp】

正题 题目大意 nnn个数n−1n-1n−1个或−-−号的一个算式&#xff0c;加上一些括号使得运算结果最大。 解题思路 对于号左右的两个数字&#xff0c;无论如何加括号都不会变结果&#xff0c;所以我们可以合并这些数。然后就只剩下了减号&#xff0c;此时除了第一个就可以随意选…

.Net Core Cors中间件解析

同源策略和资源跨域共享1、同源策略同源策略&#xff0c;它是由Netscape提出的一个著名的安全策略。现在所有支持JavaScript 的浏览器都会使用这个策略。所谓同源是指&#xff0c;域名&#xff0c;协议&#xff0c;端口相同。1.1、目的主要是为了保证用户信息的安全&#xff0c…

BZOJ 3513: [MUTC2013]idiots [FFT]

统计每种长度的木棒数量&#xff0c;先计算出两根棒子能构成的长度&#xff0c;想到卷积。1.拿这个序列卷积自己 2.计算重算的部分&#xff0c;首先是一条边自己和自己的这种情况&#xff0c;另一种是(i,j)和(j,i)这种形式。第一种&#xff0c;可以枚举读入的木棒长度&#xff…

【暴力】I Liked Matrix!

I Liked Matrix! 题目大意&#xff1a; 有一个矩阵&#xff0c;求出某一些子矩阵内最大的数 原题&#xff1a; 题目描述 给定一个 n ∗ m 的矩阵 A&#xff0c;对其进行 q 次询问&#xff1a;以 (x1, y1) 为左上角&#xff0c;(x2, y2) 为右下角的子矩 阵中&#xff0c;所…

jzoj6805-NOIP2020.9.26模拟speike【扫描线】

正题 题目大意 一个平面上&#xff0c;起点是(0,0)(0,0)(0,0)&#xff0c;终点是(0,t)(0,t)(0,t)。有nnn个没有共同面积的矩形障碍物&#xff0c;对于每个障碍物不可以从内部穿过而可以从边上走过。求最短路。 解题思路 因为没有共同面积所以横坐标不会变小。并且只有在边界处…

【dfs】I Like Matrix!

I Like Matrix! 题目大意&#xff1a; 有一个矩阵&#xff0c;还有一些走法&#xff0c;从1,1开始可以走到多少个位置 原题&#xff1a; 题目描述 给定 k 种移动方式&#xff1a;从 (i, j) 移动到 (i xk, j yk)&#xff08;xk, yk > 0&#xff09;。询问在一个 n ∗ …

Full_of_Boys训练3总结

题目来源: 2016-2017 ACM-ICPC Pacific Northwest Regional Contest E.Enclosure 先计算出内外两个凸包&#xff0c;枚举大凸包上的点&#xff0c;在小凸包上找到两个切点。计算面积时&#xff0c;就相当于删掉几条原先的边&#xff0c;加上一个新的三角形。同时&#xff0c;可…

P3188-[HNOI2007]梦幻岛宝珠【背包】

正题 题目链接:https://www.luogu.com.cn/problem/P3188 题目大意 nnn个物品&#xff0c;大小为WWW的背包。 每个物品的大小可以表示为wiai2biw_ia_i2^{b_i}wi​ai​2bi​&#xff0c;有价值viv_ivi​。 求选择一些物品不超过背包的大小使得价值最大。 解题思路 设先计算bi…

【DP】I Will Like Matrix!

I Will Like Matrix! 题目大意&#xff1a; 有一个01矩阵&#xff0c;a[i][j1]a[i][j1]a[i][j1]和a[i1][j]a[i1][j]a[i1][j]必须大于a[i][j]a[i][j]a[i][j],问有多少种填法 原题&#xff1a; 题目描述 在一个 n ∗ m 的矩阵 A 的所有位置中分别填入 0 或 1&#xff0c;要求…

用Way.EntityDB进行Entity Framework Core数据库建模

Way.EntityDB是一个基于EF Core的数据层框架&#xff0c;它取消了EF Core的Migration机制&#xff0c;因为Migration并不是通用的&#xff0c;比如说sql server生成的migration&#xff0c;如果换成sqlite&#xff0c;运行时会报错的&#xff0c;也就是数据库不能更换。Way.Ent…

AT4513-[AGC030D]InversionSum【dp】

正题 题目链接:https://atcoder.jp/contests/agc030/tasks/agc030_d 题目大意 nnn个数&#xff0c;ppp次操作可以选择操作或者不操作&#xff0c;询问所有情况下逆序对的总和。 解题思路 转换成期望的问题&#xff0c;设fi,jf_{i,j}fi,j​表示所有情况下ai<aja_i<a_jai…

【dfs】【模拟】【树】I Like Matrix Forever!

I Like Matrix Forever! 题目大意&#xff1a; 有一个01矩阵&#xff0c;有一些操作&#xff1a;反转一个位置的数&#xff0c;反转一行的数&#xff0c;反转一列的数&#xff0c;回到第i次操作&#xff0c;每一次操作还要输出1的个数 原题&#xff1a; 题目描述 对一个 n…

Full_of_Boys训练4总结

题目来源&#xff1a;2017-2018 ACM-ICPC Southwestern European Regional Programming Contest (SWERC 2017) A.Cakey McCakeFace #include <bits/stdc.h> #define pb(x) push_back(x) typedef long long ll; const int maxn 20007; using namespace std; int n,m; ll …

.NET Core开发日志——Runtime IDentifier

.NET Core对于传统.NET开发人员而言是既熟悉又陌生的新平台&#xff0c;所以有时遇上出乎意料的事情也纯属正常情况。这时只需点耐心&#xff0c;多查查资料&#xff0c;努力找到原因&#xff0c;也未尝不是件有意义的体验。比如当建完一个最简单的控制台应用程序&#xff1a;d…

P3723-[AH2017/HNOI2017]礼物【FFT】

正题 题目链接:https://www.luogu.com.cn/problem/P3723 题目大意 两个长度为nnn的序列xxx和yyy&#xff0c;可以旋转序列xxx之后让一个序列的所有数加上一个非负整数ccc。 要求最小化∑i1n(xi−yi)2\sum_{i1}^n(x_i-y_i)^2i1∑n​(xi​−yi​)2 解题思路 其实就是要求最小…

初一模拟赛总结(5.11)

成绩&#xff1a; rank是有算其他dalaodalaodalao的 rankrankranknamenamenamescorescorescoreT1T1T1T2T2T2T3T3T3T4T4T4T5T5T5333lyflyflyf420420420100100100100100100100100100100100100202020444hkyhkyhky400400400100100100100100100100100100100100100000444fyfyfy40040…