.Net微服务实践(四)[网关]:Ocelot限流熔断、缓存以及负载均衡
2021-03-23 14:24
标签:location 功能 global 路由 foreach nav cal 服务发现 存在 在上篇.Net微服务实践(三)[网关]:Ocelot配置路由和请求聚合中我们介绍了Ocelot的配置,主要特性路由以及服务聚合。接下来,我们会介绍Ocelot的限流、熔断、缓存以及负载均衡。 我们先来看限流的配置 Reroute节点中的配置如下: GlobalConfiguration中的配置如下: 配置说明 在Reroute和GlobalConfiguration节点中添加了RateLimitOptions节点 示例说明 验证 修改配置,运行示例程序, 访问http://localhost:5000/api/orders,第一次可以正常获取返回结果,再次访时,显示"您的请求量超过了配额1/10分钟, 并且response状态码是999 PeriodTimespan的验证 修改Period为1s, 修改PeriodTimespan为10,这样当前的配置是1秒中允许一个请求,10秒后才能重试。 再次运行示例程序。 访问http://localhost:5000/api/orders,第一次可以正常获取返回结果, 等待两秒,再次访问,大家想一下,这个时候,会不会返回正常结果(已经过了两秒)。这时还是返回999,为什么? 因为尽管配额上是允许的,但是因为配置是客户端10秒以后才能重试,而这时只等待了2秒,所以还是返回999. Ocelot的熔断使用了Polly来实现,在OcelotGateway项目添加Polly包 注入Polly 修改配置 配置说明 在Reroute节点中添加了QoSOptions节点 示例说明 当访问http://localhost:5000/api/orders出现2次异常后,服务熔断5秒,如果服务响应超过2秒,也触发熔断条件 验证 场景一:服务宕机 场景二:超时 启动网关,启动order-api,访问http://localhost:5000/api/orders,返回503 启动网关,启动order-api,访问http://localhost:5000/api/orders, 不触发熔断 缓存使用了CacheManageer来实现,添加CacheManager包 注入缓存组件 Ocelot.json配置文件修改 缓存是根据 downstream service 的URL来缓存的 在Reroute节点中添加了FileCacheOptions节点 示例说明 当访问http://localhost:5000/api/orders后,结果会缓存60秒,在缓存有效期内即使原始的order api的返回结果发生变化,通过网关请求时,还是会返回缓存的结果。 验证 因为结果被缓存了 因为缓存有效期已经过了 Ocelot允许在上游服务的request和下游服务的response的header中添加、替换信息 配置如下: 配置说明 在Reroute节点中添加了DownstreamHeaderTransform节点和UpstreamHeaderTransform节点 说明:在下游服务的response中添加一个header, key是devops, value是rdc 示例说明 当访问http://localhost:5000/api/orders后,结果会缓存60秒,在缓存有效期内即使原始的order api的返回结果发生变化,通过网关请求时,还是会返回缓存的结果。 验证 Ocelot允许在路由时转化HTTP方法 示例说明 适用场景:例如有些已经存在的的API,因为某些历史原因都是用POST,在通过网关对外提供服务时,就可以按照标准API进行转换 验证 Ocelot内置了负载均衡,我们先来看配置 配置说明 验证 第一次的结果是 第二次的结果是 第三次的结果是 Ocelot本身是一组中间件,它也提供了方式来注入和重写其中的某些中间件: 下面是注入PreErrorResponderMiddleware中间件的代码示例: 注意: Ocelot也是一组中间件,所以可以在Ocelot中间件之前,按常规方式添加任何中间件, 但是不能在Ocelot中间件之后添加,因为Ocelot没有调用 next Ocelot提供了一组后台管理的API, 从前三篇文章可以看出,Ocelot主要也就是配置文件的管理,所以API主要也就是管理配置 本篇我们介绍了Ocelot的限流、熔断、缓存、负载均衡以及其他一些特性。到目前为止,Ocelot的基本配置和功能都已经介绍完了。接下里我们会结合consul来介绍服务发现,以及Ocelot和Consul的集成。 示例代码下载地址: https://github.com/lcyhjx/ocelot-demo/tree/master .Net微服务实践(四)[网关]:Ocelot限流熔断、缓存以及负载均衡 标签:location 功能 global 路由 foreach nav cal 服务发现 存在 原文地址:https://www.cnblogs.com/lcyhjx/p/12687152.html
限流
{
"DownstreamPathTemplate": "/api/orders",
"DownstreamScheme": "http",
"DownstreamHostAndPorts": [
{
"Host": "localhost",
"Port": 5001
}
],
"UpstreamPathTemplate": "/api/orders",
"UpstreamHttpMethod": [ "Get" ],
"RateLimitOptions": {
"ClientWhitelist": [],
"EnableRateLimiting": true,
"Period": "10m",
"PeriodTimespan": 3,
"Limit": 1
}
}
"GlobalConfiguration": {
"BaseUrl": "http://localhost:5000",
//限流
"RateLimitOptions": {
"QuotaExceededMessage": "您的请求量超过了配额1/10分钟",
"HttpStatusCode": 999
}
}
客户端在10分钟之内只允许请求一次http://localhost:5000/api/orders,在请求之后3秒钟之后可以重试熔断
services
.AddOcelot()
.AddPolly();
{
"DownstreamPathTemplate": "/api/orders",
"DownstreamScheme": "http",
"DownstreamHostAndPorts": [
{
"Host": "localhost",
"Port": 5001
}
],
"UpstreamPathTemplate": "/api/orders",
"UpstreamHttpMethod": [ "Get" ],
"QoSOptions": {
"ExceptionsAllowedBeforeBreaking": 2,
"DurationOfBreak": 5000,
"TimeoutValue": 2000
}
}
修改配置,只启动网关,不启动oder api,访问http://localhost:5000/api/orders,第一次有响应耗时,返回500,第二次也有响应耗时,返回500. 第三次则快速返回503 Service Unavalible, 服务熔断了。
修改配置
修改api/orders代码,等待3秒// GET: api/orders
[Route("api/orders")]
[HttpGet]
public IEnumerable
修改配置
修改api/orders代码,抛出异常// GET: api/orders
[Route("api/orders")]
[HttpGet]
public IEnumerable
缓存
Install-Package Ocelot.Cache.CacheManager
services.AddOcelot()
.AddCacheManager(x =>
{
x.WithDictionaryHandle();
});
{
"DownstreamPathTemplate": "/api/orders",
"DownstreamScheme": "http",
"DownstreamHostAndPorts": [
{
"Host": "localhost",
"Port": 5001
}
],
"UpstreamPathTemplate": "/api/orders",
"UpstreamHttpMethod": [ "Get" ],
"FileCacheOptions": {
"TtlSeconds": 60,
"Region": "orders"
}
}
配置说明
"刘明的订单", "王天的订单"
[Route("api/orders")]
[HttpGet]
public IEnumerable
"刘明的订单", "王天的订单"
"帅的订单", "我的订单"
Header转化
{
"DownstreamPathTemplate": "/api/shopping-carts",
"DownstreamScheme": "http",
"DownstreamHostAndPorts": [
{
"Host": "localhost",
"Port": 5001
}
],
"DownstreamHeaderTransform": {
"devops": "rdc"
},
"UpstreamPathTemplate": "/api/shopping-carts",
"UpstreamHttpMethod": [ "Get" ],
"UpstreamHeaderTransform": {
"lakin": "rdc",
"CI": "msbuild, jenkins",
"Location": "http://localhost:5001, {BaseUrl}"
}
}
"DownstreamHeaderTransform": {
"devops": "rdc"
}
"UpstreamHeaderTransform": {
"lakin": "rdc",
"CI": "msbuild, jenkins",
"Location": "http://localhost:5001, {BaseUrl}"
}
在上游服务的request中添加一个header, key是lakin, value是rdc
在上游服务的request中, 将key是CI的header, 其值由msbuild替换为jenkins
在上游服务的request中, 将key是Location的header, 其值由http://localhost:5001替换为{BaseUrl} placehokder
// GET: api/shopping-carts
[Route("api/shopping-carts")]
[HttpGet]
public IEnumerable
"CI": "msbuild",
"Location": "http://localhost:5001"
开始打印header信息CI
lakin - rdc
CI - jenkins
Location - http://localhost:5000
打印header信息完成
devops - rdc
HTTP方法转换
{
"DownstreamPathTemplate": "/api/shopping-carts",
"DownstreamScheme": "http",
"DownstreamHttpMethod": "POST",
"DownstreamHostAndPorts": [
{
"Host": "localhost",
"Port": 5001
}
],
"UpstreamPathTemplate": "/api/shopping-carts",
"UpstreamHttpMethod": [ "Get" ]
}
上述示例中,将GET /api/shopping-carts 路由到 POST /api/shopping-carts, 将GET转换成了POST
"洗发水", "无人机"
[Route("api/shopping-carts")]
[HttpPost]
public string Post()
{
return "添加商品到购物车成功";
}
添加商品到购物车成功
负载均衡
{
"DownstreamPathTemplate": "/api/orders",
"DownstreamScheme": "http",
"DownstreamHostAndPorts": [
{
"Host": "localhost",
"Port": 5001
},
{
"Host": "localhost",
"Port": 6001
}
],
"UpstreamPathTemplate": "/api/orders",
"UpstreamHttpMethod": [ "Get" ],
"LoadBalancerOptions": {
"Type": "RoundRobin"
}
}
在DownstreamHostAndPorts指指定多个服务地址
在Reroute节点中添加LoadBalancerOptions,这是负载均衡的配置节点,其中Type属性指定了负载均衡的算法, 它有如下几个值:
[Route("api/orders")]
[HttpGet]
public IEnumerable
[Route("api/orders")]
[HttpGet]
public IEnumerable
"刘明的订单", "王天的订单"
"帅的订单", "我的订单"
"刘明的订单", "王天的订单"
注入/重写中间件
//注入中间件
var configuration = new OcelotPipelineConfiguration
{
PreErrorResponderMiddleware = async (ctx, next) =>
{
ctx.HttpContext.Request.Headers.Add("myreq", "ocelot-request");
await next.Invoke();
}
};
app.UseOcelot(configuration).Wait();
后台管理
POST {adminPath}/connect/token
GET {adminPath}/configuration
POST {adminPath}/configuration
DELETE {adminPath}/outputcache/{region}最后
上一篇:CSS3(10)多列
下一篇:PHP正则反斜杠的讲究
文章标题:.Net微服务实践(四)[网关]:Ocelot限流熔断、缓存以及负载均衡
文章链接:http://soscw.com/essay/67835.html