.Net Core服务治理Consul自动扩展和服务调用
今天有写文章的时间了,开心。延续上一篇的话题继续,顺便放上一篇的传送门:点这里。
服务调用
既然服务注册已经搞完了,那么现在就开始调用这些注册好的服务。先做一下准备动作,把consul容器跑起来:

打开控制台确认正常:

然后多跑几个应用程序模拟多点部署:

程序跑完以后检察一下服务列表:

戳进去看看:

一切准备就绪,完美。然后进入编码环节。老规矩,直接上码:
public static string Convert(string consulUri, string centerName, string reqUri)
{
ConsulClient client = new ConsulClient(x =>
{
x.Address = new Uri(consulUri);
x.Datacenter = centerName;
});
//获取consul中注册的服务列表
var consulServiceList = client.Agent.Services().Result.Response;
//统一请求地址
Uri uri = new Uri(reqUri);
//取出分组名称
string groupName = uri.Host;
//匹配出对应的服务
var serviceList = consulServiceList.Where(x => x.Value.Service.ToLower().Equals(groupName.ToLower())).ToArray();
//随机访问策略
var service = serviceList[new Random().Next(serviceList.Length)].Value;
return $"{uri.Scheme}://{service.Address}:{service.Port}{uri.PathAndQuery}";
}上面是自行封装的方法,作用很简单:把通用的请求地址转换为实际发起请求的地址,比如调用起来是这样的:
string realUri = ConsulService.Convert("http://127.0.0.1:8700", "dc1", "http://shenzhen-ma/v1/client/base/index");发现了么,分组名称“shenzhen-ma”直接替代了具体的ip和端口。这样做真的可以拿到请求结果么?随便写一个测试用的controller:
public async Task<IActionResult> Post()
{
string realUri = ConsulService.Convert("http://127.0.0.1:8700", "dc1", "http://shenzhen-ma/v1/client/base/index");
string result = await Service.Tool.HttpHelper.Get(realUri);
return Ok(result);
}看请求结果:

5001应用程序请求到了5004的数据。多试几下再看看:



很显然,通过统一的请求地址,实际的请求分发到了不同的节点上。
复盘一波
到刚才,我已经完成了服务调用这个关键步骤。consul做了什么呢?它帮我们把统一的请求地址转换成了真实发生作用的请求地址。未来如果增加了新的服务器,无需调整,它自己就能够发现新的服务——这就是大家广泛理解的服务发现。实际上,这个功能就赋予了我们动态增加节点的能力。能伸能缩,是微服务的一个重要特征。当然,因为没有配置健康检查,我的consul现在还不能自动移除不可用的服务,能伸不能缩,很尴尬。这个么,时间有限,放在下一篇文章去写。这一篇文章能讲清楚服务调用,并由此能理解什么是服务发现,我觉得就达标。
到此这篇关于.Net Core服务治理Consul自动扩展和服务调用的文章就介绍到这了。希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
相关文章
在ASP.NET 2.0中操作数据之六十一:在事务里对数据库修改进行封装
事务的最主要的一个作用就是保证数据的完整性,本文主要介绍ASP.NET 2.0中使用事务对修改数据进行封装,这些包含事务的命令要么都执行成功要么都执行失败。2016-05-05
NopCommerce架构分析之(六)自定义RazorViewEngine和WebViewPage
本文对NopCommerce的后台分离技术做简单的探讨。NopCommerce通过自定义视图引擎,重写了VirtualPathProviderViewEngine类的CreateView、CreatePartialView、FindView、FindPartialView方法,添加自定义的视图搜索路径来实现后台分离。2016-04-04
ASP.NET MVC4入门教程(八):给数据模型添加校验器
本文介绍给模型添加校验器,以前我们做表单验证都要前台验证一遍,后台再验证一遍,MVC4中这种方式,只需在模型上加验证规则,前后台就都验证了。2016-04-04
NopCommerce架构分析之(三)EntityFramework数据库初试化及数据操作
本文介绍IStartupTask,该类会在系统启动时执行,IStartupTask调用IEfDataProvider进行数据库的初始化。2016-04-04
在ASP.NET 2.0中操作数据之四:使用ObjectDataSource展现数据
前面介绍搭建基础的架构,下面我们来介绍ASP.NET中,如何利用ObjectDataSource来展现数据。通过配置ObjectDataSource,我们指定这些底层的对象,还有这些对象的方法如何映射到ObjectDataSource的Select、Insert、Update和Delete方法。2016-04-04
在ASP.NET 2.0中操作数据之十八:在ASP.NET页面中处理BLL/DAL层的异常
本文主要介绍ASP.NET 2.0中如何在页面中处理BLL和DAL层的异常,程序演示了如何在页面中显示友好的异常信息,以及讲解了如何在DAL层抛出自定义异常。2016-05-05
在ASP.NET 2.0中操作数据之五十二:使用FileUpload上传文件
本文主要介绍ASP.NET中为了演示上传文件,我们在数据库上建了两个字段,分别存储二进制图片和PDF路径,然后介绍了如何使用FileUpload 完成上传文件。2016-05-05
.NET多种数据库大数据批量插入、更新(支持SqlServer、MySql、PgSql和Oracle)
这篇文章介绍了.NET多种数据库大数据批量插入、更新。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下2021-11-11


最新评论