当前位置: 首页 > news >正文

【微服务】.Net中使用Consul实现服务高可用

目录

一、目的

二、Consul概述

三、安装和部署

3.1 下载Consul

3.2 安装和运行

3.3 访问Consul的UI页面

四、.Net中使用Consul

4.1 安装Nuget包

4.2 .Net注册服务

4.3 服务健康检测

4.4 服务使用

五、调用Consul示例

六、文章总结


一、目的

       在微服务架构中,为了保证服务的高可用,通常需要在服务使用中,通过负载均衡配置,来分发流量和提高系统可用性扩展系统服务的吞吐能力。并消除系统中的单点故障,提升应用系统的可用性。一般来说Nginx就可以实现负载均衡的功能。但是,因为Nginx无法灵活的动态添加服务,因此一般在微服务架构中,会通过一些中间件来实现,服务发现的框架常用的有:consul、zookeeper等。

        这里主要介绍的是在.Net环境下Consul实现服务发现等相关功能。

        

二、Consul概述

        Consul 是一个分布式、高度可用的数据中心感知服务发现平台,包括简单的服务注册、运行状况检查、故障检测和密钥值存储。 它基于这样一个前提:数据中心中的每个节点都运行一个 Consul 代理,并充当服务器或客户端。 每个代理通过可缩放的 gossip 协议进行通信。

        

三、安装和部署

3.1 下载Consul

        Consul官网地址:Consul | HashiCorp Developer ,Consul安装非常简单,在官网,点击download

ps:这里我们可以看到Consul支持多种操作系统可选,这里我们在window上测试,这里选择windows。

3.2 安装和运行

        Consul安装:下载后,解压即可。解压后只有一个consul.exe可执行文件。

        Consul运行命令如下(进入CMD命令行):

cd 对应盘符文件夹\consul_1.17.1_windows_amd64//启动Consulconsul agent -dev//设置ip地址访问-需要时配置consul agent -dev -client=0.0.0.0

3.3 访问Consul的UI页面

        启动后会显示如下内容:

        浏览器中访问地址,http://localhost:8500/ 判断Consul服务是否运行成功。

ps:以上是Consul基本的单机部署,为保证高可用可以对Consul进行集群部署。

四、.Net中使用Consul

4.1 安装Nuget包

        在业务服务中Nuget安装: Consul,把业务服务注册到Consul中

dotnet add packages Consul

4.2 .Net注册服务

        把当前服务的相关地址信息,添加到Consul中:


using Consul;
using Microsoft.Extensions.Configuration;
using System;namespace MicroService.Framework;
public static class ConsulHelper
{/// <summary>/// Consul注册/// </summary>/// <param name="configuration"></param>public static void ConsulRegist(this IConfiguration configuration){//准备链接Consul的ClientConsulClient client = new ConsulClient(c =>{c.Address = new Uri("http://localhost:8500/");c.Datacenter = "test1";});//找到consulstring ip = string.IsNullOrWhiteSpace(configuration["ip"]) ? "127.0.0.1" : configuration["ip"];int port = string.IsNullOrWhiteSpace(configuration["port"]) ? 9001 : int.Parse(configuration["port"]);//命令行参数必须传入//int weight = string.IsNullOrWhiteSpace(configuration["weight"]) ? 1 : int.Parse(configuration["weight"]);client.Agent.ServiceRegister(new AgentServiceRegistration(){ID = "service" + Guid.NewGuid(),//唯一idName = "test_server",//Group--分组Address = ip,Port = port,//Tags = new string[] { weight.ToString() },//标签Check = new AgentServiceCheck(){Interval = TimeSpan.FromSeconds(10),//间隔10s一次HTTP = $"http://{ip}:{port}/Api/Health/Index",//健康检测接口Timeout = TimeSpan.FromSeconds(3),//检测等待时间DeregisterCriticalServiceAfter = TimeSpan.FromSeconds(60)//失败后多久移除}});//命令行参数获取Console.WriteLine($"注册成功:{ip}:{port}");}
}

        程序启动时注册一次:

       

4.3 服务健康检测

        增加一个健康检测接口,接口映射到管道中间件中处理,自定义返回结果:

public static class HealthExtention
{public static void Health(this WebApplication app){app.MapWhen(context => context.Request.Path.Equals("/Api/Health/Index"),applicationBuilder => applicationBuilder.Run(async context =>{Console.WriteLine($"This is Health Check");context.Response.StatusCode = (int)HttpStatusCode.OK;await context.Response.WriteAsync("OK");}));}
}

4.4 服务使用

        运行业务服务,使用端口来区分不同的业务逻辑

dotnet run --urls=http://localhost:9001 --port=9001

五、调用Consul示例

        客户端需要引用Consul的组件,正常微服务模式下,客户端只需要请求网关即可,请求通过网关会转发到其他服务层。

        

        客户端调用Consul中的服务示例

  //consul获取服务api/users/all也得知道string url = null;url = "http://test_server/api/users/all";//consul就像dns--只是负责解析ip:port--清单ConsulClient client = new ConsulClient(c =>{c.Address = new Uri("http://localhost:8500/");c.Datacenter = "test1";});var response = client.Agent.Services().Result.Response;//获取服务清单Uri uri = new Uri(url);string groupName = uri.Host;//服务实例AgentService agentService = null;var dictionary = response.Where(s => s.Value.Service.Equals(groupName, StringComparison.OrdinalIgnoreCase)).ToArray();{//agentService = dictionary[0].Value;//写死第一个}{轮询策略 也是平均,但是太僵硬了agentService = dictionary[iIndex++ % dictionary.Length].Value;}//可自定义负载策略url = $"{uri.Scheme}://{agentService.Address}:{agentService.Port}{uri.PathAndQuery}";string content = InvokeApi(url);var res = JsonConvert.DeserializeObject<IEnumerable<User>>(content);

六、文章总结

        在微服务架构中,使用Consul作为服务发现和配置管理的工具是非常常见的。Consul由HashiCorp开发,提供了一个完整的解决方案,其中包括服务发现、健康检查、键值存储以及多数据中心支持。

        把之所学,以文载之~ 欢迎大家多多交流

相关引用:

https://zhuanlan.zhihu.com/p/701107409

使用 Consul 作为成员管理器 - .NET | Microsoft Learn

http://www.lqws.cn/news/577279.html

相关文章:

  • 大语言模型微调的效能控制与评估策略
  • 提示技术系列——链式提示
  • 跨主机用 Docker Compose 部署 PostgreSQL + PostGIS 主从
  • 对象池模式:减少GC的Kotlin实战指南
  • 基于 SpringBoot+Vue.js+ElementUI 的 Cosplay 论坛设计与实现7000字论文
  • LeetCode 1456. 定长子串中元音的最大数目
  • MapReduce
  • EtherCAT主站教程4--IGH主站代码详解
  • 云手机的用途都有哪些?
  • Deep Mean-Shift Priors for Image Restoration论文阅读
  • mysql mvcc
  • Hadoop WordCount 程序实现与执行指南
  • Java 案例 6 - 数组篇(基础)
  • 第 89 场周赛:山脉数组的峰值索引、车队、考场就坐、相似度为 K 的字符串
  • 大语言模型(LLM)笔记
  • UE5 一台电脑+双显示器 配置nDisplay裸眼3D效果
  • 东芝TC78S600FNG在打印机中的应用:静音、防卡纸与能效
  • Python 数据分析与机器学习入门 (八):用 Scikit-Learn 跑通第一个机器学习模型
  • 智慧畜牧-猪场猪只行为状态检测数据集VOC+YOLO格式3790张15类别
  • Java中for与foreach
  • python+uniapp基于微信小程序的生鲜订购系统nodejs+java
  • 基于uniapp的老年皮肤健康管理微信小程序平台(源码+论文+部署+安装+售后)
  • JAVA八股文:异常有哪些种类,可以举几个例子吗?Throwable类有哪些常见方法?
  • HTML5 实现的圣诞主题网站源码,使用了 HTML5 和 CSS3 技术,界面美观、节日氛围浓厚。
  • 湖北理元理律师事务所债务解法:从法律技术到生活重建
  • 车载Tier1 supplier梳理
  • VMware vSphere 9与ESXi 9正式发布:云原生与AI驱动的虚拟化平台革新
  • Nginx反向代理与缓存功能
  • 【软考高项论文】信息系统项目的资源管理
  • GitHub Actions配置python flake8和black