.Net Core微服务入门——Consul服务注册与发现(一)

26 篇文章 1 订阅
13 篇文章 1 订阅

Consul服务注册与发现

服务注册与发现

服务注册:
简单理解,就是有一个注册中心,我们的每个服务实例启动时,都去注册中心注册一下,告诉注册中心我的地址,端口等信息。同样的服务实例要删除时,去注册中心删除一下,注册中心负责维护这些服务实例的信息。

服务发现:
既然注册中心维护了各个服务实例的信息,那么客户端通过注册中心就很容易发现服务的变化了。
有了服务注册与发现,客户端就不用再去配置各个服务实例的地址,改为从注册中心统一获取。
那注册中心又是怎么保证每个地址的可用状态呢,假如某个实例挂了怎么办呢?原则上挂掉的实例不应该被客户端获取到,所以就要提到:健康检查 。

健康检查:
每个服务都需要提供一个用于健康检查的接口,该接口不具备业务功能。服务注册时把这个接口的地址也告诉注册中心,注册中心会定时调用这个接口来检测服务是否正常,如果不正常,则将它移除,这样就保证了服务的可用性。
常见注册中心有 Consul、ZooKeeper、etcd、Eureka。

Consul下载安装

Consul官网:https://www.consul.io/
Consul的主要功能有服务注册与发现、健康检查、K-V存储、多数据中心等。

Consul安装:很简单,直接在官网下载解压即可。
Consul运行:在consul.exe目录下打开命令行执行 consul.exe agent -dev

在这里插入图片描述

浏览器访问:http://localhost:8500/

在这里插入图片描述

Consul接入

1、引入 Consul 包
在这里插入图片描述

2、新增 Consul 配置
在 appsettings.json 中新增Consul 配置

"ConsulSetting": {
    "ConsulAddress": "http://localhost:8500/", //注意,docker容器内部无法使用localhost访问宿主机器,如果是控制台启动的话就用localhost
    "ServiceName": "MyApi", //服务名
    "ServiceHealthApi": "/api/health", //心跳检查api
    "ServiceHealthInterval": "10", //心跳检查频率
    "ServiceHealthTimeout": "5" //心跳检查超时时间
  },

在这里插入图片描述
3、增加 ConsulHelper 类

public static class ConsulHelper
{
     public static void ConsulRegist(this IConfiguration configuration)
     {
         ConsulClient client = new ConsulClient(c =>
         {
             // c.Address = new Uri("http://localhost:8500/");
             c.Address = new Uri(configuration["ConsulSetting:ConsulAddress"]);
             //c.Datacenter = "dc1";
         });

         string ip = configuration["ip"];// ip 命令行参数必须传入
         int port = int.Parse(configuration["port"]);//命令行参数必须传入
         int weight = string.IsNullOrWhiteSpace(configuration["weight"]) ? 1 : int.Parse(configuration["weight"]);
         var serviceName = configuration["ConsulSetting:ServiceName"];
         var ServiceHealthApi = configuration["ConsulSetting:ServiceHealthApi"];
         var serviceHealthInterval = string.IsNullOrWhiteSpace(configuration["ConsulSetting:ServiceHealthInterval"]) ? 10: int.Parse(configuration["ConsulSetting:ServiceHealthInterval"]);
         var serviceHealthTimeout = string.IsNullOrWhiteSpace(configuration["ConsulSetting:ServiceHealthTimeout"]) ? 10 : int.Parse(configuration["ConsulSetting:ServiceHealthTimeout"]);

         client.Agent.ServiceRegister(new AgentServiceRegistration()
         {
             ID = Guid.NewGuid().ToString(),//服务实例唯一标识 //$"{serviceName}_{port}",//唯一的
             Name = serviceName,//组名称-Group
             Address = ip,//其实应该写ip地址
             Port = port,//不同实例
             Tags = new string[] { weight.ToString() },//标签
             Check = new AgentServiceCheck()
             {
                 Interval = TimeSpan.FromSeconds(serviceHealthInterval),//间隔10s一次
                 HTTP= $"http://{ip}:{port}{ServiceHealthApi}", //心跳地址
                 
                 Timeout = TimeSpan.FromSeconds(serviceHealthTimeout),//检测等待时间
                 DeregisterCriticalServiceAfter = TimeSpan.FromSeconds(20)//失败后多久移除
             }
         });
     }
 }

4、在 Startup 启动时注册ConsulHelper

this.Configuration.ConsulRegist();

在这里插入图片描述

5、新增心跳检测 HealthController

[ApiController]
[Route("api/[controller]")]
 public class HealthController : ControllerBase
 {
     /// <summary>
     /// 健康检查接口
     /// </summary>
     /// <returns></returns>
     [HttpGet]
     public IActionResult Get() => Ok("ok");
 }

6、通过Consul运行,查看结果

打开启动命令提示符窗口,进入项目dll目录

运行命令

dotnet MyAPI.dll --urls=http://127.0.0.1:5011 --ip=127.0.0.1 --port=5011

在这里插入图片描述

浏览器打开 http://localhost:5011/api/health ,查看结果

在这里插入图片描述
http://localhost:8500 控制台查看,多了一个MyApi
在这里插入图片描述

注:

dotnet MyAPI.dll --urls=http://127.0.0.1:5011 --ip=127.0.0.1 --port=5011 命令中: ip、port 必须和ConsulHelper 代码中的参数一致

在这里插入图片描述
weight 可以不指定,代码中默认1 ,也可以指定,如:

dotnet MyAPI.dll --urls=http://127.0.0.1:5011 --ip=127.0.0.1 --port=5011 --weight 1

7、再运行两个端口

打开两个窗口,分别运行

dotnet MyAPI.dll --urls=http://127.0.0.1:5012 --ip=127.0.0.1 --port=5012
dotnet MyAPI.dll --urls=http://127.0.0.1:5013 --ip=127.0.0.1 --port=5013 

打开 http://localhost:5012/api/health 、 http://localhost:5013/api/health,查看结果

在这里插入图片描述

http://localhost:8500/ 控制台查看

在这里插入图片描述
查看详情
在这里插入图片描述

关闭5013端口,查看效果:

在这里插入图片描述

下一章我们将介绍,Consul在Docker 中运行等

https://blog.csdn.net/weixin_41003771/article/details/118726566

  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是一些可能出现的.NET Core微服务面试题和答案: 1. 什么是微服务架构?微服务架构有哪些优缺点? 答:微服务架构是一种将应用程序拆分成多个较小、独立的服务的架构。每个服务都有自己的业务逻辑和数据存储,可以独立部署和扩展。微服务架构的优点包括:高可用性、高可扩展性、易于维护和更新、更好的团队协作和快速开发;缺点包括:复杂性、部署和测试的挑战、需要额外的管理和监控。 2. .NET Core微服务架构有什么关系? 答:.NET Core是微软开发的跨平台开发框架,可以用于构建微服务架构。.NET Core提供了许多工具和库,使得在.NET Core中实现微服务变得更加容易和高效。 3. 请简述一下如何在.NET Core中实现微服务架构? 答:在.NET Core中实现微服务架构需要遵循以下步骤: 1)拆分应用程序,将业务逻辑和数据存储拆分成多个服务; 2)选择适当的微服务框架,如ASP.NET Core、Service Fabric、Dapr等; 3)实现服务之间的通信,可以使用HTTP、TCP、Message Queue等协议和工具; 4)实现服务注册发现,可以使用Consul、Eureka、Zookeeper等工具; 5)实现负载均衡和容错机制,可以使用Ribbon、Hystrix等工具。 4. 请列举.NET Core中常用的微服务框架? 答:ASP.NET Core、Service Fabric、Dapr、Steeltoe等都是.NET Core中常用的微服务框架。 5. 如何在微服务架构中实现服务发现和负载均衡? 答:可以使用Consul、Eureka、Zookeeper等工具来实现服务注册发现,使用Ribbon、Hystrix等工具来实现负载均衡和容错机制。 6. 如何在微服务架构中实现服务容错和故障恢复? 答:可以使用Hystrix、Polly等库来实现服务容错和故障恢复。这些库提供了诸如断路器、超时、重试等功能,可以帮助应用程序处理各种故障情况。 7. 请说明.NET Core中的服务注册发现的实现方式? 答:.NET Core中可以使用Consul、Eureka、Zookeeper等工具来实现服务注册发现。这些工具可以将服务的网络地址和元数据注册到中央服务注册表中,其他服务可以通过查询这个注册表来发现需要调用的服务。 8. 请说明如何使用.NET Core实现微服务架构中的认证和授权? 答:可以使用IdentityServer4、OpenID Connect等库来实现微服务架构中的认证和授权。这些库提供了诸如OAuth2、JWT等功能,可以帮助应用程序实现安全的身份验证和授权。 9. 请简述一下如何在.NET Core中实现微服务之间的通信? 答:可以使用HTTP、TCP、Message Queue等协议和工具来实现微服务之间的通信。在.NET Core中,可以使用HttpClient、gRPC、RabbitMQ等工具来实现微服务之间的通信。 10. 如何在.NET Core中实现微服务架构中的API网关? 答:可以使用Ocelot、Zuul等库来实现微服务架构中的API网关。这些库可以将微服务的API聚合在一起,提供统一的入口点和路由策略,以便于管理和监控微服务

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值