应无所住,而生其心
排名
1
文章
872
粉丝
112
评论
163
net core webapi post传递参数
庸人 : 确实坑哈,我也是下班好了好几次,发现后台传递对象是可以的,但...
百度编辑器自定义模板
庸人 : 我建议换个编辑器,因为现在百度富文本已经停止维护了,用tinymec...
ICP备案 :渝ICP备18016597号-1
网站信息:2018-2025TNBLOG.NET
技术交流:群号656732739
联系我们:contact@tnblog.net
公网安备:50010702506256
欢迎加群交流技术

.net core3.1使用API网关Ocelot四:实现熔断

9641人阅读 2020/9/1 14:40 总访问:5416105 评论:0 收藏:0 手机
分类: 微服务

接上一篇:.net core3.1使用API网关Ocelot三:请求缓存与限流
https://www.tnblog.net/aojiancc2/article/details/4983

熔断的意思是停止将请求转发到下游服务。当下游服务已经出现故障的时候再请求也是徒劳,并且还会增加下游服务器和API网关的负担,类似保险丝。Ocelot熔断使用的是Polly,我们只需要为路由做一些简单配置即可


添加Polly依赖

先下载Polly依赖

  1. install-package Ocelot.Provider.Polly

然后在ConfigureServices中添加Polly的依赖,注意是在AddOcelot()后点出来的


添加熔断配置

  1. "QoSOptions": {
  2. "ExceptionsAllowedBeforeBreaking": 2, // 允许多少个异常请求
  3. "DurationOfBreak": 5000, // 熔断的时间,单位为毫秒
  4. "TimeoutValue": 3000 // 如果下游请求的处理时间超过多少则视如该请求超时
  5. }

这个配置的意思是,3秒算一次超时(TimeoutValue:3000),然后允许的异常请求是2次(ExceptionsAllowedBeforeBreaking:2),如果达到了允许异常请求的上限就触发5秒钟的熔断时间(DurationOfBreak:5000)

如图


修改一下接口方便模拟一下测试


这里我们可以使用传递一个延迟时间的方式来测试,可以很方便的把熔断的方式都测试出来

传递3秒以下的都能被正常的访问到

但是传递3000以上的就会出现服务访问不到的情况

说明熔断的超时配置起作用了

如果只出现一次马上把延迟时间修改为3000以下就会可以马上访问成功,因为还没有达到配置熔断的限制次数所以还可以立即访问到。但是要注意这一次也会访问不到,因为超过了我们设置的超时时间,不要把这一次的超时和触发熔断的时间搞混了,还要注意如果设置超时时间是3000,测试的时候弄成3001,3002这种和超时时间极为接近的时间可能会触发不了,所以测试的时候要适当的把测试时间改大一点

但是当我们尝试让他两次都超时后,就会触发熔断时间,就是你把延迟时间修改为3000以下(模拟接口已经恢复正常了),还是不能被立即访问到。要过5秒后才能重新请求,因为我上面DurationOfBreak配置的是5000

项目下载:
https://download.tnblog.net/resource/index/3e2f58ea38ce44679ee1d28add4c4e2b


欢迎加群讨论技术,1群:677373950(满了,可以加,但通过不了),2群:656732739。有需要软件开发,或者学习软件技术的朋友可以和我联系~(Q:815170684)

评价

net core 使用 EF Code First

下面这些内容很老了看这篇:https://www.tnblog.net/aojiancc2/article/details/5365 项目使用多层,把数据库访问...

使用OLEDB读取不同版本Excel的连接字符串设置

使用OleBD读取excel的时候,excel不同的版本,连接字符串的写法也会不一样。///<summary> ///读取excel ///</su...

C 使用CancellationTokenSource取消多线程

有时间我们在使用多线程的时候,需要取消线程的执行,可以使用CancellationTokenSource来取消对Task开辟多线程的取消如下:...

使用爬虫刷csdn博客访问量

首先了解一下常见反爬虫的检测方法频率监测:有些网站会设置一种频率监测的机制,对于同一IP,若在一定时间内访问的速度超...

Idea下使用maven搭建SSM(一):SpringMVC

Spring MVC是一款基于MVC架构模式的轻量级Web框架,其目的是将Web开发模块化,对整体架构进行解耦,简化Web开发流程。下面...

Idea下使用maven搭建SSM(二):MyBatis

开发Web应用,数据的存储和处理往往离不开数据库和SQL语句。在使用Java开发的Web应用中,自然也少不了连接数据库的步骤。在...

使用 微软自带语音合成类库

//引入语音合成名称空间 usingSystem.Speech.Synthesis; classA { voidtest1() { //实例化并指定字符串播放合成读音 ...

如何使用图标像使用文字一样,使用文本图标的方法

1.首先在Iconfont-阿里巴巴矢量图标库上面找到你需要的图标然后加入你的购物车然后选择图标;注意:每个类型的图标会大小不...

使用七牛云的cdn服务,提高图片的加载速度

CDN介绍CDN的全称是Content Delivery Network,即内容分发网络。CDN加速主要是加速静态资源,如网站上面上传的图片、媒体,...

.net core 使用session

tip:net core 2.2后可以直接启用session了,不用在自己添加一次session依赖,本身就添加了使用nuget添加引用Microsoft.AspN...

使用OutLook发送邮件

publicstaticvoidOutlook(stringSubject,stringTextBody,stringFromAdd,stringFromPass,stringTo,stringCC,List<string&...

SQL Server 中使用游标

--声明一个游标 DECLAREMyCursorCURSOR FORSELECTTOP5FBookName,FBookCodingFROMTBookInfo//定义一个叫MyCursor的游标,...

Windows使用wireshark抓包小心得

wireshrak是个网络抓包工具,常用。但是在数据较大的网络环境中直接使用软件抓包会导致wireshark卡死。为什么呢 ?网卡瞬间...

Oracle自定义函数的简单使用

一.最最最简单的返回一个数字的函数createorreplacefunctionfun_show returnint--申明返回值 as begin return1; end;...

Oracle事务的简单使用

事务:  事务是一个整体,这些操作要么全部执行成功,要么全部不执行。使用事务的原因:保证数据的安全有效。事务的四个特...

Oracle使用游标

其实游标就是把查询的结果放入游标中,然后在去游标里边读取。相当于使用游标做了一个中转,而游标是可以作为参数进行传递...