Consul初探-集成ocelot

前言

由于 Consul 的高可用性、丰富的API、友好的 Web 控制台界面等特点,Consul 的发展非常迅猛,得益于 .NETCore 社区的快速发展和社区成员的贡献,我们现在可以非常方便快速的将 Consul 集成到 .NETCore 中,在 Ocelot 的集成方面也是非常的便捷,在 API Gateway 项目中,只需要通过引用一个包,就可以在项目中服务发现了。

今天要完成的架构图

640?wx_fmt=png

上面就是今天要完成的业务架构图,客户端、Ocelot 网关、Consul 集群、计算器服务集群,这几个模块组成了基本的分布式网关模型。

建立 APIGateway 项目

建立空项目

首先我们建立一个空的 Asp.NetCore WebApplication 程序,对于一个简单的网关程序来说,空项目足够了,因为我们写代码的地方不多

640?wx_fmt=png

Ocelot 的包引用

640?wx_fmt=png

我们只需要引用 Ocelot.Provider.Consul ,即可完成 ocelot 和 consul 的依赖引用

640?wx_fmt=png

配置网关

首先,我们需要为 ocelot 网关编写一个配置文件,ocelot 的配置功能非常丰富,具体参考:https://ocelot.readthedocs.io/en/latest/,本次我们只编写一个最简单的 ocelot.json 文件,该配置文件决定了客户端的请求该如何转发到从 Consul 发现到真正的服务实例中。

{	"ReRoutes": [	{	"UseServiceDiscovery": true, // 使用服务发现	"DownstreamPathTemplate": "/{url}", // 转发路由规则	"DownstreamScheme": "http", // 协议	"ServiceName": "node-1", // 服务名称	"LoadBalancerOptions": { // 负载均衡的算法(这里使用平均)	"Type": "RoundRobin"	},	"UpstreamPathTemplate": "/{url}", //  下游请求路由	"UpstreamHttpMethod": [ "Get", "Post" ], // 支持请求方法	"ReRoutesCaseSensitive": false // 路由大小写敏感设置	}	],	"GlobalConfiguration": { // 网关全局配置	"RequestKey": "OcRequestId",	"ServiceDiscoveryProvider": { // 服务发现的配置	"Host": "172.16.1.218",	"Port": 8500,	"ConfigurationKey": "node-1"	}	}	
}

上面就是 ocelot 网关的配置,接下来,还需要在 Startup.cs 类中进行简单的配置。

进行服务注入
  1. public void ConfigureServices(IServiceCollection services)

  2. {

  3. var ocelotConfig = new ConfigurationBuilder().AddJsonFile("ocelot.json", false, true).Build();

  4. services.AddOcelot(ocelotConfig)

  5. .AddConsul()

  6. .AddConfigStoredInConsul();

  7. }

首先加载 ocelot.json 文件,然后将配置注入到服务中

设置路由转发
  1. public void Configure(IApplicationBuilder app, IHostingEnvironment env)

  2. {

  3. app.UseHttpsRedirection()

  4. .UseOcelot()

  5. .Wait();

  6. }

通过上面的代码,将 ocelot 注入请求管道中,到这里,配置的工作就已经完成了

创建一个计算器服务

为了演示网关转发和服务发现,我们需要构建一个简单的计算器服务,我准备使用该计算器服务运行两个实例,两个实例运行于同一台服务器上,分别侦听 12008/12009 端口,在服务启动后,该计算器服务将会自动的把自己注册到 Consul 代理服务器集群中,然后 APIGateway 网关从 Consul 发现 12008/12009 服务,并使用负载均衡的机制对两个服务进行调用。

为了方便演示,这里的计算器服务就使用上一篇的代码进行测试了

640?wx_fmt=png

运行计算器服务(12008/12009)

我们需要启动两个服务实例,然后注册到 Consul 中,启动服务

640?wx_fmt=gif

查看 Consul 代理服务器集群的状态

640?wx_fmt=png

服务注册正常

启动 ocelot 网关

640?wx_fmt=png

访问 Ocelot 网关

计算器服务(12008/12009) 服务实例提供的路由地址为:/home/add/{x:int}/{y:int} ,ocelot 网关的侦听地址为:http://172.16.10.227:12200 ,根据路由转发规则,ocelot 网关会把客户端的请求完整的转发到 12008/12009 服务实例上,所以我们可以通过下面的 url 请求服务,即:ocelot网关+12008/12009 路由,组合起来就是:http://172.16.10.227:12200/home/add/{x:int}/{y:int},那么真正的请求 url 为:http://172.16.10.227:12200/home/add/10/10,预期输出结果为:30

640?wx_fmt=gif

通过上面的输出,可以看到,从网关到真正的服务实例,这个环节已经打通了,通过不断的刷新网页请求,下方的两个服务实例总是一前一后的持续输出日志,这就足以证明我们在 ocelot 服务网关配置的负载均衡算法 "Type": "RoundRobin" 发挥了作用。

ocelot 配置文件管理

通过查看 Consul Web 控制台的界面的 Key/Value 菜单,发现 ocelot 将配置文件 ocelot.json 存储到 Consul 中了,我们可以在 Consul 中对网关进行可视化管理,修改保存即可。

640?wx_fmt=png

结束语

从实验结果看,在 .NETCore 中集成 APIGateway 和 Consul 还是比较简单的事情,当然,大部分的项目在项目开放进程中,大概率是不会一次性使用到这么多组件的,不过我相信,随着架构的演进,这些项目最终也不得不考虑服务注册、发现、调度、负载均衡等这些问题,引入网关,就势在必行了。

.NETCore 集成 Consul 导读

  • 1、Consul初探-在深交之前先认识

  • 2、Consul初探-从安装到运行

  • 3、Consul初探-服务注册和发现

  • 4、Consul初探-集成ocelot

源代码下载

本文所有源代码已托管到 Github ,欢迎下载测试 https://github.com/lianggx/Examples/tree/master/Ron.Consul ,如果觉得还行,请点击 star ,谢谢支持。

640?wx_fmt=jpeg


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

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

相关文章

Codeforces Round #682 (Div. 2)D Powerful Ksenia ///思维

cf地址 题目大意:Ksenia has an array a consisting of n positive integers a1,a2,…,an. In one operation she can do the following: choose three distinct indices i, j, k, and then change all of ai,aj,ak to ai⊕aj⊕ak simultaneously, where ⊕ denot…

2021年广东工业大学第十五届文远知行杯程序设计竞赛(同步赛) H.有多短 思维

传送门 文章目录题意:思路:题意: 思路: 可以发现树的直径起点和终点一定是两个度数为111的点,所以我们可以把kkk平均的分给所有度数为111的点,这样答案就为2∗kcnt\frac{2*k}{cnt}cnt2∗k​。 证如果分配给…

Identity和IdentityServer的区别及联系

关于Identity和IdentityServer初学的时候可能会有一些疑惑(虽然我也不是很精深吧),但是,这里说一下自己关于这两者的一些理解,如有错误,欢迎指正总体上,ASP.NET Core Identity提供了一个用来管理和存储用户账户的框架.IdentitySer…

Educational Codeforces Round 96 (Rated for Div. 2) C. Numbers on Whiteboard///思维

cf地址 题目大意:给一个数n,有1~n的数,每次现在两个数a,b,将这两个数去掉,然后添加一个(ab)/2的数(向上取整),进行n-1次操作后,问你最…

2016中国大学生程序设计竞赛(长春)Sequence II HDU - 5919 主席树

传送门 文章目录题意:思路:题意: 给一个长度为nnn的序列,每次一个询问[l,r][l,r][l,r],求其中数第一次出现的位置的中位数。 思路: 先考虑一下如何求区间内不同数的个数。 因为要求位置的中位数&#xf…

C#规范整理·集合和Linq

LINQ(Language Integrated Query,语言集成查询)提供了类似于SQL的语法,能对集合进行遍历、筛选和投影。一旦掌握了LINQ,你就会发现在开发中再也离不开它。  开始!前言C#中的集合表现为数组和若干集合类。不管是数组还…

UVA - 11361 Investigating Div-Sum Property(数位dp/记忆化搜索板子)

题目:https://vjudge.net/problem/UVA-11361 思路:数位dp,用记忆化搜索写,dp[pos][i][j][limit] 代表剩余有pos位,每位上的数字和模k 等于i, 当前总数值模k等于j,limit代表限制位。 本题还要注意…

CodeCraft-21 and Codeforces Round #711 (Div. 2) D. Bananas in a Microwave 优化暴力

传送门 文章目录题意:思路:题意: 有nnn个时间,每个时间给你两个操作,第一个是kkxkkxkkx,第二个是kk∗xkk*xkk∗x,且可以执行[0,y][0,y][0,y]次,kkk初始状态为000,求[1,m…

C#并发编程之异步编程(三)

写在前面本篇是异步编程系列的第三篇,本来计划第三篇的内容是介绍异步编程中常用的几个方法,但是前两篇写出来后,身边的朋友总是会有其他问题,所以决定再续写一篇,作为异步编程(一)和异步编程(二)的补充。本篇内容主要…

UVA - 10253 Series-Parallel Networks(递推式、记忆化搜索写法)

题目:UVA-10253 题目翻译(来自蓝书): 串并联网络有两个端点,一个叫源,一个叫汇,递归定义如下: (1) 一条单独的边是串并联网络。 (2)…

Codeforces Round #163 (Div. 2) C. Below the Diagonal 分治

传送门 文章目录题意:思路:题意: 给你一个n∗nn*nn∗n的矩阵,给你n−1n-1n−1个位置,这些位置为111,其他位置为000,操作定义为交换两行或者交换两列,让你通过不超过1e51e51e5次操作…

C#规范整理·泛型委托事件

基于泛型,我们得以将类型参数化,以便更大范围地进行代码复用。同时,它减少了泛型类及泛型方法中的转型,确保了类型安全。委托本身是一种引用类型,它保存的也是托管堆中对象的引用,只不过这个引用比较特殊&a…

C - Digital Path 计蒜客 - 42397(dp记忆化搜索)

题目:vj地址 思路:dp[i][j][k]代表 以i,j结尾 有k长度的路径数量,k最大等于4,如果k超过4,也是等于4. 那么转移:dp[i][j][k]{dp[x][y][k-1]}(x,y满足a[x][y]1a[i][j]); 如果k4,还有dp[i][j][k]{d…

Prefix HDU - 5790 字典树 + 主席树

传送门 文章目录题意:思路:题意: 给你nnn个串,每次询问一个区间,返回这个区间的串的不同的前缀个数,强制在线。 思路: 碰到字符串前缀的问题,我们自然的想到用字典树来解决。 对于…

Abp v0.18.0 新版本: MVC Module 启动模板

0.18.0将于近期发布, 本文内容针对于0.18.0版本.MVC模块启动模板可用此模板开发基于模块开发最佳实践和约定的可复用 应用程序模块 . 它同样适用于开发微服务.如何开始?你可以使用ABP CLI创建基于此启动模板的新项目,或者你也可以在入门页面创建并下载项目. 在这里我们使用CLI…

M - Kill the tree 计蒜客 - 42552(2019icpc徐州/树的重心/树形dp)

vj地址 题目大意:找到每一颗子树的重心 思路: 树的重心的性质: 树的重心如果不唯一,则至多有两个,且这两个重心相邻 通过连接一条端点分别在两个树的边,来将两个树合并成一个,那么新的重心肯定…

Consul-template+nginx实现自动负载均衡

前言consul-template 是 Consul 的一个守护程序,使用 consul-template 可以方便快速的实现对 Consul Key/Value 存储系统的访问,可以从 KV 系统中读取数据、监视变动、同步本地文件;还可以在执行模板更新的同时,执行本地系统命令&…

Codeforces Round #613 (Div. 2) E. Delete a Segment 离散化

传送门 文章目录题意:思路:题意: 思路: 我们考虑将区间内的位置都111,之后求区间段数就可以转换成求,连续不为000的区间段数,由于范围有[−1e9,1e9][-1e9,1e9][−1e9,1e9]的级别,所…

C - Insertion Sort Gym - 101955C(2018icpc沈阳/打表找规律)

VJ地址 这道题,首先要把表打出来,表打出来 规律就很容易发现了,一列中它们的差值是等差数列,可以发现公差为2 * dp[j][i], 首项为i * dp[j][i]; 很多人都是直接简化公式,我发现在数据范围内可以用递推来算出…

是时候挥别 SQL Server 2008 了

微软 宣布将于 2019 年 7 月终止对 SQL Server 2008 和 2008 R2 的支持,使用 SQL Server 2008 的公司应该认真开始考虑下一步了。本文引用了一家数字化转型咨询公司高级顾问对此的分析,并提供了一些解决方案和注意事项。如果你还在使用 微软 2008 版的 S…