ASP.NET Core中Ocelot的使用:基于服务发现的负载均衡

本系列相关文章:

  • 《ASP.NET Core中Ocelot的使用:API网关的应用》

  • 《ASP.NET Core中Ocelot的使用:基于Spring Clound Netflix Eureka的动态路由》

本文将基于前两篇文章所述内容,继续介绍如何在服务发现和动态路由的基础上,使用Ocelot实现负载均衡。Ocelot本身是带有负载均衡功能的,这一点其实跟Nginx提供的HTTP load balancer是类似的功能(我觉得整个Ocelot提供的功能,通过Nginx也都可以实现,不过Ocelot更加.NET化,对于.NET开发人员来说更为简单和容易接受)。根据官方文档,Ocelot支持如下几种负载均衡策略:

  • LeastConnection:根据服务当前正在处理的请求个数来决定将使用哪个服务来处理新接收到的请求,将请求转发给当前连接数最少的服务

  • RoundRobin:经典模式,轮询法,逐个选择可用的服务来处理接收到的请求

  • NoLoadBalancer:仅使用第一个可用的服务来处理接收到的请求

  • CookieStickySessions:通过使用Cookie,确保特定的请求能够被分配到特定的服务上进行处理

今天我们选择RoundRobin来看看如何基于服务发现来实现负载均衡。同样,首先需要对架构进行调整。

调整架构

与上文中的架构相比,这里不会引入新的服务,而相比之下会让两个A服务的实例同时运行。调整后的架构如下图所示:

640?wx_fmt=png

整个API的调用过程如下:

  1. A服务的两个实例、B服务以及API网关在启动的时候均向Spring Cloud Eureka注册自己

  2. API用户通过访问Eureka获得API网关的地址

  3. API用户使用获得的API网关地址,发送一个查询A服务的请求

  4. API网关根据指定的A服务的名称,从Eureka查询A服务所注册的服务实例

  5. API网关根据设定的负载均衡策略,向找到的服务实例发出请求,并将调用结果反馈给API用户

可以看到,前面部分的调用过程与上文所述都是非常类似的,不同的仅有API网关在寻找A服务的实例这个部分,前面是直接获得访问地址,而此处则通过负载均衡来选择一个地址。接下来,我们看看如何改变我们的代码,来实现这个架构。

代码修改

这里的代码修改会基于上文结尾时的代码,也就是实现了Ocelot的动态路由。首先,我们在计算服务(也就是A服务)中增加一个API,用以返回当前设置在主机上的machineName环境变量(如果设置为空,那么就直接返回主机机器名):

1
2
3
4
5
6
7
8
9
10
[Route("api/[controller]")]
[ApiController]
public class ValuesController : ControllerBase
{
    [HttpGet("info")]
    public ActionResult<string> Info()
        => Environment.GetEnvironmentVariable("machineName") ?? Environment.MachineName;
    // 其它代码省略
}

然后,就是配置Ocelot,使其能够实现负载均衡:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
{
  "ReRoutes": [
  ],
  "GlobalConfiguration": {
    "RequestIdKey": "OcRequestId",
    "AdministrationPath": "/administration",
    "ServiceDiscoveryProvider": {
      "Host": "localhost",
      "Port": 8761,
      "Type": "Eureka",
      "Token": null,
      "ConfigurationKey": null
    },
    "LoadBalancerOptions": {
      "Type": "RoundRobin"
    },
    "DownstreamScheme": "http"
  }
}

只需注意上面的LoadBalancerOptions部分,这里我们采用了RoundRobin模式,这个配置文件的其它部分都与之前的一样,没有区别。

好了,代码改好了。什么?就改好了?对的,就是这么简单!接下来让我们测试一下。先在Eclipse里启动Spring Cloud Eureka:

640?wx_fmt=png

然后,进入CalcService的编译输出目录,首先设置machineName环境变量,然后用下面的命令启动服务:

640?wx_fmt=png

用同样的命令再启动另一个CalcService的实例:

640?wx_fmt=png

OK,两个CalcService的实例已经启动,分别侦听49814和49815两个端口,接下来,启动我们的Ocelot API网关。等Ocelot API网关启动之后,查看Eureka的服务注册,可以看到所有的服务已经就绪:

640?wx_fmt=png

请注意,对于CALC这个应用程序,我们可以看到,有两个实例已经注册成功。然后,我们通过访问API网关进而访问刚刚新加的Info API,可以看到,服务调用成功。然后按F5刷新,可见返回的结果会在CalcService-1与CalcService-2之间来回切换,也就意味着我们的请求被依次分配到两个不同的Calc服务的实例上执行。动图为证:


由此可见,我们已经实现了基于Ocelot API网关的负载均衡。当然,我们可以继续修改ASP.NET Core MVC的前端页面,让它能够直观地显示这个效果。这里也就不贴代码了,大家可以按本文后面的源代码链接下载源码,自己研究。

解决方案容器化

同样,我们可以把整个解决方案容器化,与上一篇文章所述的容器化有区别的一点是,对于CalcService的Dockerfile,我们要扩充它的EXPOSE的端口范围,原来是写死的49814,现在让它能够曝露从49800到49899的所有端口,以便新的服务可以通过不同的端口接收请求。此外,还需要在docker-compose.yml中增加另一个Calc服务的配置,详细可以仿照docker-compose.yml中已有的服务配置信息,这里也不多啰嗦了,源代码库中有完整的内容供参考。

完成这些配置之后,可以直接用docker-compose一次性启动所有服务,然后看看我们的API页面,其中的“计算服务名称”会随着页面的刷新动态改变:

640?wx_fmt=gif

总结

本文对前文的案例做了一些简单的调整,实现了基于Ocelot API网关的负载均衡。其实,负载均衡还可以实现在某个微服务的多个实例的层面,然后将这个层面的负载均衡器地址注册到Eureka上,也是可以的。这样的架构能够更好地控制每个服务的伸缩,并对其进行监控。接下来的文章中,我会继续尝试基于微服务的一些部署拓扑,以及在云中如何运行我们的微服务架构。

源代码的使用

请访问https://github.com/daxnet/ocelot-sample/releases/tag/chapter_3下载本文相关案例的源代码。

相关文章:

  • AspNetCore中使用Ocelot之 IdentityServer4

  • Ocelot-基于.NET Core的开源网关实现

  • .NET Core微服务之基于Ocelot+IdentityServer实现统一验证与授权

  • Swagger如何访问Ocelot中带权限验证的API

  • Ocelot.JwtAuthorize:一个基于网关的Jwt验证包

  • .NET Core微服务之基于Ocelot实现API网关服务

  • .NET Core微服务之基于Ocelot实现API网关服务(续)

  • .NET微服务体系结构中为什么使用Ocelot实现API网关

  • Ocelot简易教程(一)之Ocelot是什么

  • Ocelot简易教程(二)之快速开始1

  • Ocelot简易教程(二)之快速开始2

  • Ocelot简易教程(三)之主要特性及路由详解

  • Ocelot简易教程(四)之请求聚合以及服务发现

  • Ocelot简易教程(五)之集成IdentityServer认证以及授权

  • Ocelot简易教程(六)之重写配置文件存储方式并优化响应数据

  • Ocelot简易教程(七)之配置文件数据库存储插件源码解析

  • ASP.NET Core中Ocelot的使用:API网关的应用

  • ASP.NET Core中Ocelot的使用:基于Spring Cloud Netflix Eureka的动态路由

原文地址: http://sunnycoding.cn/2018/11/06/aspnetcore-ocelot-service-discovery-load-balancing/


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

640?wx_fmt=jpeg

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

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

相关文章

CF643F-Bears and Juice【组合数学】

正题 题目链接:https://www.luogu.com.cn/problem/CF643F 题目大意 题目有点奇怪就直接放翻译了 有 nnn 只熊和若干桶果汁和恰好一桶酒&#xff0c;每一天每只熊会选择一些桶&#xff08;可能不选&#xff09;并各喝一 杯&#xff0c;喝到酒的熊会去睡觉并不再回来&#xff…

【模板】Manacher算法

ACM模板 目录初始化以及构造初始化以及构造 数组下标从1开始即cin>>s1 由于奇回文串和偶回文串某些性质不同&#xff0c;我们首先通过init()操作使得新串中所有回文串的长度都变成奇数&#xff0c;返回值是新串的长度&#xff08;原串中的下标i对应新串中的2i&#xff09…

POJ2155 - Matrix(二维树状数组)

POJ2155 - Matrix 文章目录题目题解&#xff1a;代码题目 给你一个二维矩阵&#xff0c;初始化为0&#xff0c;然后可以进行两次操作&#xff1a; C:x,y,x1,y2 对该小矩阵内的数进行取反 Q:查询某个点是0还是1 题解&#xff1a; C是区间修改&#xff0c;Q是单点查询&#xf…

牛客挑战赛48C-铬合金之声【Prufer序列】

正题 题目链接:https://ac.nowcoder.com/acm/contest/11161/C 题目大意 nnn个点加mmm条边使得不存在环&#xff0c;每种方案的权值是所有联通块的大小乘积。 求所有方案的权值和。 1≤n≤109,1≤m≤1071\leq n\leq 10^9,1\leq m\leq 10^71≤n≤109,1≤m≤107 解题思路 就是分…

F - Sugoroku2(期望dp)

F - Sugoroku2 期望dp&#xff1a;fuf_ufu​表示到达终点的期望于是有 fu{0,u≥nf0,u∈Afu1⋯fumm1f_u\begin{cases} 0,u\ge n \\f_0,u\in A\\ \frac{f_{u1}\dotsf_{um}}{m}1 \end{cases}fu​⎩⎪⎨⎪⎧​0,u≥nf0​,u∈Amfu1​⋯fum​​1​ 由于存在返回f0f_0f0​的操作&…

.NET Core2使用Azure云上的Iot-Hub服务

基于工业4.0大背景下的工业物联网是近几年内热门的话题&#xff0c;依靠信息化技术企业可以实现数字化转型&#xff0c;生产可以实现智能化制造&#xff0c;设备可以实现自动化运作。然而&#xff0c;海量的数据采集是整个建设过程的基础环节&#xff0c;如何处理与利用这海量的…

Matrix Subtraction(小米icpc邀请赛第一场)

Matrix Subtraction 题意&#xff1a; 一个给定的矩阵&#xff0c;然后给定一个子矩阵的大小&#xff0c;子矩阵可以 将覆盖矩阵的区域的值减1&#xff0c;问能否将矩阵全部减为0 题解&#xff1a; 思路和下面这个链接讲的题十分相似 传送 本质就是二维树状数组差分求解 用…

E - Rotate and Flip(线性代数矩阵坐标变换)

E - Rotate and Flip 顺时针 [010−100001][xy1][y−x1]\begin{bmatrix} 0 & 1 & 0\\ -1&0&0\\0 &0&1 \end{bmatrix}\begin{bmatrix} x\\y\\1 \end{bmatrix}\begin{bmatrix} y\\-x\\1 \end{bmatrix}⎣⎡​0−10​100​001​⎦⎤​⎣⎡​xy1​⎦⎤​⎣…

CF755G-PolandBall and Many Other Balls【倍增FFT】

正题 题目链接:https://www.luogu.com.cn/problem/CF755G 题目大意 nnn个东西排成一排&#xff0c;每个组可以选择一个单独的物品或者两个连续的物品&#xff0c;一个物品不同同时在两个组里&#xff0c;但是可以不在组里。对于i∈[1,k]i\in[1,k]i∈[1,k]求分成iii组的方案数。…

Intelligent Warehouse(小米邀请赛)

题目 题意&#xff1a; n个数字&#xff0c;问存在的最长的一组数&#xff0c;使得其中任意两个数的都是倍数关系&#xff0c;问最长的长度是多少 题解&#xff1a; 暴力。。。 没想到暴力就能做&#xff0c;当时就该交上去试试的 用dp[i]表示当期选的所有数都是i的约数且符…

SmartCode.ETL 这不是先有鸡还是蛋的问题!

继国庆节 SmartCode 正式版&#xff08;SmartCode.Generator&#xff09;发布之后&#xff0c;SmartCode 迎来了新的能力 SmartCode.ETL !SmartCode 正式版从开始发布就从未说过自己仅仅是个代码生成器&#xff0c;这点上从我第一次宣布SmartCode正式开源的文章就可以说明&…

codeforces1469 E. A Bit Similar

E. A Bit Similar 代码抄的这份题解 找到一个长度为k的串使得在s长度为k的子串中&#xff0c;对于所有子串答案串都至少有一位相同。也就是如果将s长度为k的子串全部按位取反&#xff0c;那么答案串不能与这些反串匹配。 现在问题转化成&#xff0c;找到一个答案串&#xff…

对拍

参考博客 晚上不想刷题。。无聊的开始研究对拍 以前oi的时候看过对拍&#xff0c;奈何当时水平太差根本用不上对拍&#xff0c;&#xff08;现在水平也不咋地。。&#xff09; 上面那个博文讲的非常好。。 对拍最终的就是 对拍程序.bat 首先第一步&#xff1a;生成一组输入数据…

P7444-「EZEC-7」猜排列【dp】

正题 题目链接:https://www.luogu.com.cn/problem/P7444 题目大意 一个长度为nnn的排列&#xff0c;已知每个cic_ici​表示那个排列中mexmexmex为iii的区间个数。求满足条件的排列个数 1≤n≤5105,ci≥0,∑i1ncin(n1)2−11\leq n\leq 5\times 10^5,c_i\geq 0,\sum_{i1}^nc_i\…

dubbo线程池为什么耗尽

文章概述 大家可能都遇到过DUBBO线程池打满这个问题&#xff0c;报错如下&#xff0c;本文我们就一起分析DUBBO线程池打满这个问题。 cause: org.apache.dubbo.remoting.RemotingException: Server side(10.0.0.100,20881) thread pool is exhausted, detail msg:Thread pool …

手把手教你写DI_0_DI是什么?

DI是什么&#xff1f;Dependency Injection 常常简称为&#xff1a;DI。它是实现控制反转&#xff08;Inversion of Control – IoC&#xff09;的一个模式。fowler 大大大神 “几十年”前的经典文章 https://www.martinfowler.com/articles/injection.html 说的很清楚。“几十…

C++顺序创建txt文件

今天下午在对拍数据的时候感觉好麻烦。。 一次次手调文件名称&#xff0c;突然想起可以直接写段程序集中操作 顺序输出 #include <iostream> #include <fstream> #include<string> using namespace std;int main () {ofstream File;for(int i0;i<3;i){str…

【模板】字符串哈希

ACM模板 目录构建应用构建 字符串哈希就是将字符串映射成一个数&#xff0c;哈希冲突是不可避免的&#xff0c;我们需要选用合适的base尽可能使得哈希冲突可能性降低 unsigned long long溢出后相当于取模&#xff0c;相当于模264−12^{64}-1264−1 get(l,r)函数返回字符串下标…

P5137-polynomial【倍增】

正题 题目链接:https://www.luogu.com.cn/problem/P5137 题目大意 TTT组数据给出n,a,b,pn,a,b,pn,a,b,p求 (∑01naibn−i)%p\left(\sum_{01}^na^ib^{n-i}\right)\%p(01∑n​aibn−i)%p 1≤T≤105,1≤n,a,b,p≤10181\leq T\leq 10^5,1\leq n,a,b,p\leq 10^{18}1≤T≤105,1≤n,a…

使用Visual Studio Code开发.NET Core看这篇就够了

在本文中&#xff0c;我将带着大家一步一步的通过图文的形式来演示如何在Visual Studio Code中进行.NET Core程序的开发&#xff0c;测试以及调试。尽管Visual Studio Code的部分功能还达不到Visual Studio的水平&#xff0c;但它实际上已经足够强大来满足我们的日常开发。而且…