.Net Core微服务网关Ocelot集成Consul
有consul基础的都知道,consul可以发现新增的服务,剔除掉无效的服务,赋予应用自动伸缩的能力。而ocelot如果集成了consul,那ocelot也能拥有这些能力,还可以自主选择负载均衡策略,灵活性更强。
(建议看完前一篇文章再来实践这一篇,不然可能有难度)
上干货。
首先打开上一篇新建好的项目,继续添加nuget包:
然后注册相关服务:
public void ConfigureServices(IServiceCollection services) { services.AddOcelot() .AddConsul() .AddConfigStoredInConsul(); }
接下来还需要修改下配置文件:
{ "Routes": [ { "DownstreamPathTemplate": "/{url}", "DownstreamScheme": "http", //"DownstreamHostAndPorts": [ // { // "Host": "123.123.123.123", // "Port": 5050 // } //], "UpstreamPathTemplate": "/MJ/{url}", "UpstreamHttpMethod": [ "Get", "Post" ], "ServiceName": "study_consul", "LoadBalancerOptions": { "Type": "RoundRobin" } } ], "GlobalConfiguration": { "ServiceDiscoveryProvider": { "Host": "42.193.182.64", "Port": 88 } } }
注释部分是原先常规的转发规则,变色部分是集成consul以后新增的配置。
这里说下配置项LoadBalancerOptions(负载均衡),官方实现了4个负载均衡器,分别是:
- 1、LeastConnection - 跟踪哪些服务正在处理请求,并向现有请求最少的服务发送新请求。
- 2、RoundRobin - 轮询。
- 3、NoLoadBalancer - 从配置或服务发现中获取第一个可用服务。
- 4、CookieStickySessions - 使用 cookie 将所有请求粘贴到特定服务器。
如果选择了第四个,那么需要额外的参数来描述cookie,比如:
"LoadBalancerOptions": { "Type": "CookieStickySessions", "Key": "ASP.NET_SessionId", "Expiry": 1800000 //过期时间 },
关于负载均衡器,本文不多做详解,回到主题。
consul需要单独搭建,所以我准备了一个拥有6个节点的consul集群:
然后在集群下注册了3个服务:
这时运行网关并请求,网关会把请求自动转到远程的consul,并且在已有的consul服务中轮询调用。来看一下运行结果:
多刷新几下:
如果你得到了类似的结果,恭喜你,已经完成了集成的操作。同时,还可以解锁一个新操作:热更新。
热更新
打开consul控制面板,找到Key/Value,你会发现这里多了一个键值对:
进入查看会发现,这是ocelot的配置:
这一份配置文件里包含了当前版本的ocelot支持的所有配置项,并且修改后即时生效。
改个路由证明下:
原来:"UpstreamPathTemplate": "/MJ/{url}" 现在:"UpstreamPathTemplate": "/{url}"
save以后再请求:
这感觉,酸爽。
既然是搞技术,自然不能脱离实际。上面的consul集群、consul客户端、网关程序都部署在不同的阿里云服务器上,和生产环境一样。学习的话,部署到本机也可以,consul单机也可以。如果你没有consul基础或者理解的不清晰,可以看我之前的系列文章,应该有帮助,往前翻一翻就有。友情提醒一下,单体的ocelot、consul禁止上生产,太脆弱,一挂全完。
到此这篇关于.Net Core微服务网关Ocelot集成Consul的文章就介绍到这了。希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
相关文章
NopCommerce架构分析之(七)主题Theme皮肤管理器
本文主要介绍NopCommerce的皮肤管理机制,NopCommerce提供默认的皮肤,我们也可以制作自己的皮肤,以实现个性化定制。2016-04-04[翻译]Scott Mitchell 的ASP.NET 2.0数据教程
本文主要是对Scott Mitchell 的ASP.NET 2.0数据系列教程的一个索引的整理,方便大家查看全部的教程。2016-05-05在ASP.NET 2.0中操作数据之五十九:使用SQL缓存依赖项SqlCacheDependency
当缓存数据库数据时,最理想的状态是数据一直驻留在内存,直到数据库发生了改动。在ASP.NET 2.0,可以通过编程或声明代码的方式使用SQL cache dependencies,配合SQL Server 2005来实现此功能。2016-05-05在ASP.NET 2.0中操作数据之六十八:为DataTable添加额外的列
本文介绍并使用TableAdapter向DataTable添加新的一列的方法和步骤,任何时候只要重新运行TableAdapter设置向导,用户所做的所有定制都要被覆盖,为避免出现这种情况,我们建议直接修改存储过程。2016-05-05在ASP.NET 2.0中操作数据之四十八:对SqlDataSource控件使用开放式并发
本文主要讲解ASP.NET 2.0中SqlDataSource控件通过配合SQL语句达到控制开放式并发的目的,通过在UPDATE和DELETE语句里扩展WHERE字句,SqlDataSource能应对绝大部分情况。2016-05-05ASP.NET MVC4入门教程(七):给电影表和模型添加新字段
本文使用Entity Framework Code First来实现模型类上的操作,使用代码优先的模式,从而使得直接修改代码,数据库也会做相应的改变。2016-04-04在ASP.NET 2.0中操作数据之十二:在GridView控件中使用TemplateField
本文主要讲解在GridView控件中如何使用TemplateField,从而更加高级的自定义GridView,实现自定义列表的功能。2016-05-05在ASP.NET 2.0中操作数据之七十:配置数据库连接和命令等级设置
TableAdapters将数据访问等细节进行的封装,但是默认情况下这些属性要么标记为internal要么为private,我们可以使用部分类,在部分类里使用标记为public的方法或属性。2016-05-05在ASP.NET 2.0中操作数据之三十六:在DataList里编辑和删除数据概述
本文主要介绍如何使用DataList控件进行编辑和删除数数据的操作,感兴趣的朋友可以学习一下。2016-05-05
最新评论