[.Net]使用Soa库+Abp搭建微服务项目框架(五):服务发现和健康监测
上篇文章说过,服务发现和健康监测是面向服务体系架构重要的模块,Soa库可以配置使用Consul作为服务发现服务,或者轮询已配置的服务列表作为本机服务发现。
将用Hangfire来作为服务发现与健康监测的定时执行库
具体配置信息请参考Hangfire – Background jobs and workers for .NET and .NET Core
服务发现
配置各个服务的地址列表,或者在服务启动时注册的key-value地址集合,轮询地址服务描述服务(GetRoutesDescAsync),确定服务中方法的路由,方法签名,使用方式,描述(功能,作者)等内容。
本机服务发现(InServer)
本机服务发现将轮询Address配置中的地址所对应的RoutesGetters,执行获取路由信息,并更新SoaServiceRoute中的Address集合
每个微服务都有一个Id 为 "Soa.ServiceDiscovery.InServer.GetRoutesDescAsync"的方法
获取该服务的地址,服务描述。

在服务模块初始化中已经将这个服务路由对象添加到RoutesGetters
var service = new SoaServiceRoute
{
Address = new List<SoaAddress>
{
addr
},
ServiceDescriptor = new SoaServiceDesc { Id = "Soa.ServiceDiscovery.InServer.GetRoutesDescAsync" }
};

在主服务(Soa.Sample.Web)中的appsettings.json中,配置如下:
"Discovery": "InServer"

配置服务发现,当前设置的轮询间隔为每分钟执行一次
"InServiceDiscovery": {
"Enable": true,
"JobCron": "0 * * * * ? "
}

各个服务Host的appsettings.json中,只需要配置Discovery即可:
"Discovery": "InServer",

Consul
可以使用UseConsulForDiscovery方法配置基于consul的服务发现功能
consul是google开源的一个使用go语言开发的服务发现、配置管理中心服务。内置了服务注册与发现框 架、分布一致性协议实现、健康检查、Key/Value存储、多数据中心方案
首先去consul官网下载二进制文件
Downloads | Consul by HashiCorp
安装直接下载zip包,解压后只有一个可执行的文件consul,将consul添加到系统的环境变量里面。
打开命令行并输入consul.exe agent -dev -bind {你本机的ip地址} 来运行consul服务

在主服务(Soa.Sample.Web)和各个服务Host的appsettings.json中,配置如下:
配置文件中设置Discovery
"Discovery": "Consul",

设置Consul
"ConsulServiceDiscovery": {
"Ip": "127.0.0.1",
"Port": "8500"
}

注意8500为consul所在ip地址
服务运行时将自动注册ip和服务名称到consul的kv中,待客户端调用时,只需要传入key值即可
当服务运行之后,在浏览器地址栏输入127.0.0.1:8500查看已在consul注册的服务

服务监控
在ServicesManagerController是获取服务列表和服务详情的Api接口控制器
[Route("api/[controller]/[action]")]
public class ServicesManagerController:AbpController
{
private readonly IClientServiceDiscovery clientServiceDiscovery;
public ServicesManagerController(IClientServiceDiscovery clientServiceDiscovery)
{
this.clientServiceDiscovery = clientServiceDiscovery;
}
[HttpGet]
public async Task<List<SoaAddress>> GetAddresses()
{
var addresses = await clientServiceDiscovery.GetAddressAsync();
return addresses;
}
[HttpGet]
public async Task<List<SoaServiceDesc>> GetServices(string server)
{
var routes = await clientServiceDiscovery.GetRoutesAsync();
if (routes != null && routes.Any() && !string.IsNullOrEmpty(server))
{
return (from route in routes
where route.Address.Any(x => x.Code == server)
select route.ServiceDescriptor).ToList();
}
return (from route in routes select route.ServiceDescriptor).ToList();
}
}

运行项目,在swagger中调试请求GetSoaService接口,可以获取所有服务信息

健康监测
健康监测用于确定各服务的健康程度,比如是否运行缓慢,是否链接顺畅等。
用一个简单的监测链接是否超时方式,确定这个服务是否健康。
using (var socket = new Socket(AddressFamily.InterNetwork, SocketType.Stream, ProtocolType.Tcp) { SendTimeout = timeout })
{
try
{
await socket.ConnectAsync(server.CreateEndPoint());
server.IsHealth = true;
}
catch
{
server.IsHealth = false;
}
}

在主服务(Soa.Sample.Web)和各个服务Host的appsettings.json中,配置如下:
"HealthCheck": {
"Enable": true,
"JobCron": "0/5 * * * * ? ",
"Timeout": 3000
},

这里健康监测服务的轮询时间是5s,超时时间为3000ms
运行后关闭一个微服务,若关闭Service2,请求/api/ServicesManager/GetAddresses
可以看到IsHealth变为False

项目地址:
[.Net]使用Soa库+Abp搭建微服务项目框架(五):服务发现和健康监测的更多相关文章
- 服务发现与健康监测框架Consul-DNS转发的应用
关于Consul Consul是一个提供服务注册与发现,健康监测,Key/Value存储以及多数据中心存储的分布式框架.官网地址是https://www.consul.io/,公司初步应用后我们老大觉 ...
- Github+yeoman+gulp-angular初始化搭建angularjs前端项目框架
在上篇文章里面我们说到了Github账号的申请与配置 那么当你有了Github账号并创建了一个自己的Github项目之后,首要的当然是搭建自己的项目框架啦! 本人对自己的定位是web前端狗,常用开发框 ...
- 美团分布式服务通信框架及服务治理系统OCTO
一.什么是OCTO 定义: OCTO是美团的分布式服务通信框架及服务治理系统,属于公司级基础设施,目前尚未开源. 目标: 为公司所有业务提供统一的服务通信框架,使业务具备良好的服务运营能力,轻松实现 ...
- SpringCloud:搭建微服务项目框架 microservicecloud
1.搭建整体父工程 microservicecloud 新建父工程microservicecloud,切记是Packageing是pom模式 主要是定义POM文件,将后续各个子模块公用的jar包等统一 ...
- iOS 从零到一搭建组件化项目框架
随着公司业务需求的不断迭代发展,工程的代码量和业务逻辑也越来越多,原始的开发模式和架构已经无法满足我们的业务发展速度了,这时我们就需要将原始项目进行一次重构大手术了.这时我们应该很清晰这次手术的动刀口 ...
- 基于mpvue搭建小程序项目框架
简介: mpvue框架对于从没有接触过小程序又要尝试小程序开发的人员来说,无疑是目前最好的选择.mpvue从底层支持 Vue.js 语法和构建工具体系,同时再结合相关UI组件库,便可以高效的实现小程序 ...
- Cocoapods组件化之搭建组件化项目框架
一,概述 随着公司业务需求的不断迭代发展,工程的代码量和业务逻辑也越来越多,原始的开发模式和架构已经无法满足我们的业务发展速度了,这时我们就需要将原始项目进行一次重构大手术了.这时我们应该很清晰这次手 ...
- Consul-template的简单应用:配置中心,服务发现与健康监测
简介 Consul-template是Consul的一个方扩展工具,通过监听Consul中的数据可以动态修改一些配置文件,大家比较热衷于应用在Nginx,HAProxy上动态配置健康状态下的客户端反向 ...
- Django-0-环境搭建、创建项目、启动服务
1- 创建虚拟环境名称(在虚拟机中) mkvirtualenv -p /usr/bin/python3 envname (/usr/bin/python3 - 你自己在虚拟机中的Python解释器 ...
- 简单搭建iOS开发项目框架
今天我们来谈谈如何搭建框架,框架需要做一些什么. 第一步:找到我们的目标我们的目标是让其他开发人员拿到手后即可写页面,不再需要考虑其他的问题. 第二步:我们需要做哪些东西各位跟着我一步一步来进行. 假 ...
随机推荐
- arch linux 安装
好长时间都没有更新自己的博客了,我简单翻阅了一下自己的更新记录,上一次更新好像还是在5月份左右,距今也有快半年,这半年也是遇到了很多事情,有不好的,也有好的.这半年我对在日常生活工作中使用Linux系 ...
- 【三】分布式训练---单机多卡与多机多卡组网(飞桨paddle2.0+)更加推荐spawn方式!
1. 单机多卡启动并行训练 飞桨2.0增加paddle.distributed.spawn函数来启动单机多卡训练,同时原有的paddle.distributed.launch的方式依然保留. padd ...
- C/C++ 动态解密释放ShellCode
今天在复习<加密与解密>时,在软件保护这一章中有一个代码与数据结合的案例,其原理是将代码段中的代码进行xor异或加密处理以后回写到原始位置,当程序运行后将此处的内容动态的进行解密,解密后回 ...
- ChatGPT 对接微信公众号技术方案实现!
作者:小傅哥 博客:https://bugstack.cn 沉淀.分享.成长,让自己和他人都能有所收获! 9天假期写了8天代码和10篇文章,这个5.1过的很爽! 如假期前小傅哥的计划一样,这个假期开启 ...
- 神经网络优化篇:将 Batch Norm 拟合进神经网络(Fitting Batch Norm into a neural network)
将 Batch Norm 拟合进神经网络 假设有一个这样的神经网络,之前说过,可以认为每个单元负责计算两件事.第一,它先计算z,然后应用其到激活函数中再计算a,所以可以认为,每个圆圈代表着两步的计算过 ...
- 蓝鲸:安装SaaS组件bk_monitor失败分析解决
使用./bk_install saas-o 安装发现bk_monitor(蓝鲸监控)组件报错"ERROR deploy failed: timeout". 单独尝试安装各个组件: ...
- Delphi 异常处理 详解
[1] Exception类的定义在SysUtils单元中. [2] Delphi也支持不从Exception继承的异常类,但是我觉得这么做并不十分的明智. 一.异常的源 在Delphi的应用程序中, ...
- K8S部署之VMWare网络拓扑踩坑
目录 背景 VMWare 虚拟网络 安装 Ubuntu Server 20.04 时遇到的网络问题 解决方法和解释 总结 背景 知乎上最近发现一篇好文 图解K8S(01):基于Ubuntu 20.04 ...
- NC20909 游戏
题目链接 题目 题目描述 有 n 个人围成一个环玩传球游戏,每轮游戏手里拿着球的那个人必须将球传给他(她)的一个朋友.游戏一共进行了 m 轮,初始球在第 a 个人手中,问游戏结束后球在第 b 个人手中 ...
- Vuex和普通全局对象
Vuex中的核心方法 Vuex是一个专为Vue.js应用程序开发的状态管理模式,其采用集中式存储管理应用的所有组件的状态,并以相应的规则保证状态以一种可预测的方式发生变化.每一个Vuex应用的核心就是 ...