zoukankan      html  css  js  c++  java
  • (3).NET CORE微服务 Micro-Service ---- Consul服务治理

    Consul是注册中心,服务提供者、服务提供者、服务消费者等都要注册到Consul中,这样就可以实现服务提供者、服务消费者的隔离。

    除了Consul之外,还有Eureka、Zookeeper等类似软件。

    Consul就是来存储服务器名称与IP和端口对应关系的服务器

    一、 consul 服务器安装

    consul 下载地址     https://www.consul.io/   墙外的网站  需要科学上网

    cmd运行  consul.exe agent -dev

    这是开发环境测试,生产环境要建集群,要至少一台 Server,多台 Agent  (因为如果只有一台的话,如果服务死了  整个网站就出问题了)

    开发环境中 consul 重启后数据就会丢失。

    consul 的监控页面 http://127.0.0.1:850

    consult 主要做三件事:提供服务到 ip 地址的注册;提供服务到 ip 地址列表的查询;对提供服务方的健康检查(HealthCheck);

    二、 .Net Core 连接 consul

      1.  Nuget - > Install-Package Consul   安装Consul

      2.  提供一个HealthCheck API接口 用于Consul做健康检查调用,只要返回个结果就可以  不论是什么结果。如

    复制代码
    [Route("api/[controller]")] 
    public class HealthController : Controller 
    { 
         [HttpGet] 
         public IActionResult Get() 
         { 
              return Ok("ok"); 
         } 
    }
    复制代码

       3. 服务注册 Consul 及注销

    复制代码
    public void Configure(IApplicationBuilder app, IHostingEnvironment env, IApplicationLifetime applicationLifetime) 
    { 
         if (env.IsDevelopment()) 
         { 
              app.UseDeveloperExceptionPage(); 
         } 
     
         app.UseMvc(); 
     
         string ip = Configuration["ip"]; 
         int port = Convert.ToInt32(Configuration["port"]); 
     
         string serviceName = "MsgService";
       string serviceId = serviceName + Guid.NewGuid();
       using (var client = new ConsulClient(ConsulConfig)) { //注册服务到 Consul ServiceRegister是一个异步方法 client.Agent.ServiceRegister(new AgentServiceRegistration() { ID = serviceId,//服务编号,不能重复,用 Guid 最简单 Name = serviceName,//服务的名字 Address = ip,//服务提供者的能被消费者访问的 ip 地址(可以被其他应用访问的地址,本地测试可以用 127.0.0.1,机房环境中一定要写自己的内网 ip 地址) Port = port,// 服务提供者的能被消费者访问的端口 Check = new AgentServiceCheck { DeregisterCriticalServiceAfter = TimeSpan.FromSeconds(5),//服务停止多久后反注册(注销) Interval = TimeSpan.FromSeconds(10),//健康检查时间间隔,或者称为心跳间隔 HTTP = $"http://{ip}:{port}/api/health",//健康检查地址 Timeout = TimeSpan.FromSeconds(5) } }).Wait();//Consult 客户端的所有方法几乎都是异步方法,但是都没按照规范加上Async 后缀,所以容易误导。记得调用后要 Wait()或者 await } //程序正常退出的时候从 Consul 注销服务 //要通过方法参数注入 IApplicationLifetime    //程序结束的时候会调用这个方法 applicationLifetime.ApplicationStopped.Register(()=> {     using (var client = new ConsulClient(ConsulConfig)) { client.Agent.ServiceDeregister(serviceId).Wait(); } }); } private void ConsulConfig(ConsulClientConfiguration c) { c.Address = new Uri("http://127.0.0.1:8500"); c.Datacenter = "dc1"; }
    复制代码
  • 相关阅读:
    把Orchard部署到Windows Azure Web Sites
    使用Windows Live Writer 发布博客园博客
    使用Microsoft Word 2013 发布Blog到博客园
    Java栈的简单实现
    Java中的运算符
    Java简单双向链表实现 @version 1.0
    Java中的面向对象II
    认识和分析日志文件
    两数之和问题
    括号序列算法
  • 原文地址:https://www.cnblogs.com/twinhead/p/9229011.html
Copyright © 2011-2022 走看看