.NET CORE微服务中CONSUL的相关使用

1.consul在微服务中的作用

consul主要做三件事:1.提供服务到ip的注册

2.提供ip到服务地址的列表查询

3.对提供服务方做健康检查(定时调用服务方一个用于健康检查的api接口 告诉消费方,服务方的服务是否还存在)

2.consul的下载及安装

1.consul的下载地址 www..consul.io

2.consul的安装   consul agent -dev  开发环境测试,在生产环境中要建立集群

3.consul的监控页面 http://127.0.0.1:8500

3.相关代码

   新建一个Asp.net core Web应用程序,选择Web API,名称为MsgService

1.rest服务的准备

在Controller文件夹中 新建一个控制器ValueController  ,rest服务的准备

namespace MsgService.Controllers
{
   [Route("api/[controller]")]
   [ApiController]
   public class ValuesController : ControllerBase
   {
    // GET api/values
   [HttpGet]
   public ActionResult<IEnumerable<string>> Get()
  {
    return new string[] { "value1", "value2" };
  }

// GET api/values/5
  [HttpGet("{id}")]
  public ActionResult<string> Get(int id)
  {
    return "value";
  }

// POST api/values
  [HttpPost]
  public void Post([FromBody] string value)
  {
  }

// PUT api/values/5
  [HttpPut("{id}")]
  public void Put(int id, [FromBody] string value)
  {
  }

// DELETE api/values/5
  [HttpDelete("{id}")]
  public void Delete(int id)
  {
  }
 }
}

再创建一个

namespace MsgService.Controllers
{
[Route("api/[controller]")]
[ApiController]
public class SMSController : ControllerBase
{
//发请求,报文体为{phoneNum:"110",msg:"aaaaaaaaaaaaa"},
[HttpPost(nameof(Send_MI))]
public void Send_MI(dynamic model)
{
Console.WriteLine($"通过小米短信接口向{model.phoneNum}发送短信{model.msg}");
}

[HttpPost(nameof(Send_LX))]
public void Send_LX(SendSMSRequest model)
{
Console.WriteLine($"通过联想短信接口向{model.PhoneNum}发送短信{model.Msg}");
}

[HttpPost(nameof(Send_HW))]
public void Send_HW(SendSMSRequest model)
{
Console.WriteLine($"通过华为短信接口向{model.PhoneNum}发送短信{model.Msg}");
}
}

public class SendSMSRequest
{
public string PhoneNum { get; set; }
public string Msg { get; set; }
}
}

.net core连接consul  install-package consul

2.服务的治理(服务的注册 注销 健康检查)

在新创建的Web API程序的Startup.cs中完成服务的注册

public void Configure(IApplicationBuilder app,IHostEnvironment env,IApplicationLifetime applicationTime)

{

if (env.IsDevelopment())
  {
       app.UseDeveloperExceptionPage();
  }
  else
  {
      app.UseHsts();
  }

string ip = Configuration["ip"];//获取服务的ip地址

string port = Configuration["port"];//获取服务的端口号

string serviceName = "MsgService";//服务的名称

string serviceId = serviceName +Guid().NewGuid();//服务的ID 必须保证每一个服务的id是不一样的

//consul的本地默认的ip及端口号为http://127.0.0.1:8500   可以自己进行设置

using(var consulClient = new ConsulClient(a=>{a.Address = new Uri("http://127.0.0.1:8500";a.DataCenter="dic1";)})){

AgentServiceRegistration asr = new AgentServiceRegistration();//创建一个服务代理的注册者

asr.Address = ip;

asr.Port = port;

asr.ID = serviceId;

asr.Name = serviceName;

asr.Check = new AgentServiceCheck(){ //设置健康检查间隔时间以及检查地址

  DeregisterCriticalServiceAfter = TimeSpan.FromSeconds(5),//

HTTP = $"http://{ip}:{port}/api/Health",

Interval = TimeSpan.FromSeconds(10),

TimeOut = TimeSpan.FromSeconds(5)

};

//这是一个异步方法

consulClient.Agent.ServiceRegister(asr).wait();

}

//注销服务

applicationTime.ApplicationStopped.Register(()=>{

using(var consulClient  = new ConsulClient(a=>a.Address = new Uri("http://127.0.0.1:8500")))

{

//通过服务的Id完成服务的销毁

consulClient.Agent.ServiceDeregister(serviceId).wait();

}

})
}

3.服务的发现

编写服务消费者

创建一个.net core控制台程序或者web应用程序 ,在startup.cs中

app.run(async(context)=>{

using(var consulClient= new ConsulClient(a=>a.Address=new Uri("http://127.0.0.1:8500"))){

//客户端负载均衡

var services = consulClient.Agent.Services().Result.Response.Values.Where(a=>a.Service.Equals("MsgService"));//找到服务名称为MsgService的服务

//通过随机数获取一个随机索引 去除索引为生成的随机数的服务

Random r = new Random();

int index = r.Next(service.Count());

var service = services.ElementAt(index);

await context.Response.WriteAsync($"id={service.ID},name={service.Service},ip={service.Address},port={service.Port}");

//服务

using(HttpClient http = new HttpClient())

using(var httpContent = new StringContent("{phoneNum:'119',msg:'help'}", Encoding.UTF8, "application/json")){

var http.PostAsync($"http://{service.Address}:{service.Port}/api/SMS/Send_LX", httpContent).Result;

await context.Response.WriteAsync(result.StatusCode.ToString());

}

}

})

.NET CORE微服务中CONSUL的相关使用的更多相关文章

  1. 基于.net core微服务(Consul、Ocelot、Docker、App.Metrics+InfluxDB+Grafana、Exceptionless、数据一致性、Jenkins)

    1.微服务简介 一种架构模式,提倡将单一应用程序划分成一组小的服务,服务之间互相协调.互相配合,为用户提供最终价值.每个服务运行在其独立的进程中,服务与服务间采用轻量级的通信机制互相沟通(RESTfu ...

  2. (3).NET CORE微服务 Micro-Service ---- Consul服务治理

    Consul是注册中心,服务提供者.服务提供者.服务消费者等都要注册到Consul中,这样就可以实现服务提供者.服务消费者的隔离. 除了Consul之外,还有Eureka.Zookeeper等类似软件 ...

  3. (3)学习笔记 ) ASP.NET CORE微服务 Micro-Service ---- Consul服务治理

    Consul是注册中心,服务提供者.服务提供者.服务消费者等都要注册到Consul中,这样就可以实现服务提供者.服务消费者的隔离. 除了Consul之外,还有Eureka.Zookeeper等类似软件 ...

  4. (4).NET CORE微服务 Micro-Service ---- Consul服务发现和消费

    上一章说了  Consul服务注册  现在我要连接上Consul里面的服务 请求它们的API接口 应该怎么做呢? 1.找Consul要一台你需要的服务器 1.1 获取Consul下的所有注册的服务 u ...

  5. (4)学习笔记 ) ASP.NET CORE微服务 Micro-Service ---- Consul服务发现和消费

    上一章说了  Consul服务注册  现在我要连接上Consul里面的服务 请求它们的API接口 应该怎么做呢? 1.找Consul要一台你需要的服务器 1.1 获取Consul下的所有注册的服务 u ...

  6. .NET Core微服务之基于Consul实现服务治理

    Tip: 此篇已加入.NET Core微服务基础系列文章索引 一.Consul基础介绍 Consul是HashiCorp公司推出的开源工具,用于实现分布式系统的服务发现与配置.与其他分布式服务注册与发 ...

  7. .NET Core微服务之基于Consul实现服务治理(续)

    Tip: 此篇已加入.NET Core微服务基础系列文章索引 上一篇发布之后,很多人点赞和评论,不胜惶恐,这一篇把上一篇没有弄到的东西补一下,也算是给各位前来询问的朋友的一些回复吧. 一.Consul ...

  8. ASP.NET Core 微服务初探[1]:服务发现之Consul

    ASP.NET Core 微服务初探[1]:服务发现之Consul   在传统单体架构中,由于应用动态性不强,不会频繁的更新和发布,也不会进行自动伸缩,我们通常将所有的服务地址都直接写在项目的配置文件 ...

  9. 微服务中的健康监测以及其在ASP.NET Core服务中实现运行状况检查

    1 .什么是健康检查? 健康检查几乎就是名称暗示的.它是一种检查您的应用程序是否健康的方法.随着越来越多的应用程序转向微服务式架构,健康检查变得尤其重要(Health Check).虽然微服务架构有很 ...

随机推荐

  1. Chapter 5 Blood Type——20

    "Just let me sit for a minute, please?" I begged. “就让我坐一会可以吗?” 我乞求道. He helped me sit on t ...

  2. 精读《Serverless 给前端带来了什么》

    1. 引言 Serverless 是一种 "无服务器架构",让用户无需关心程序运行环境.资源及数量,只要将精力 Focus 到业务逻辑上的技术. 现在公司已经实现 DevOps 化 ...

  3. jumpserver篇--安装(高可用性 mariadb+haproxy)

    1. 需求 为了解决目前登陆方式多种多样,防火墙配置复杂,历史操作无记录,用户权限混乱等等 2. Jumpserver测试环境搭建 2.1. 环境 os:CentOS release 6.8 mini ...

  4. 监控mysql

    Mysql服务器监控 管理MySql服务器属于应用程序监控范畴.这是因为绝大多数性能参数是有MySql软件产生的,而不属于主操作系统的一部分. 如当前所提到的,应该总是先监控基础操作系统,然后监控My ...

  5. 原型模式 prototype 创建型 设计模式(七)

    原型模式  prototype 意图 用原型实例指定需要创建的对象的类型,然后使用复制这个原型对象的方法创建出更多同类型的对象   显然,原型模式就是给出一个对象,然后克隆一个或者更多个对象 小时候看 ...

  6. 逐步搭建vs2015的API自带认证调用+跨域调用

    demo百度网盘链接:https://pan.baidu.com/s/1HJ19RJwS6qCixui8KF8QBg 提取码:yt1c 首先我们建立一个webapi项目,这个就不需要小编解释了.如下图 ...

  7. C#___.net经典题

    1 请你说说   .NET  中类和结构的区别? 答:结构和类具有大体的语法,但是结构受到的限制比类要多.结构不能申明有默认的构造函数,为结构的副本是又编译器创建 和销毁的,所以不需要默认的构造函数和 ...

  8. wpf 无缝滚动

    很早以前有项目就需要文字无缝滚动的效果但无奈当时技术不到位 人也比较懒惰(大概程序猿都是这个样子吧) 此方法并非只文字无缝其实任何内容都可以 <ScrollViewer Name="s ...

  9. C#杂记-简化的初始化

    对象说明 public class Person { public int Age{get; set;} public string Name{get; set;} List<Person> ...

  10. C# 在PPT幻灯片中创建图表

    图表能够很直观的表现数据在某个时间段的变化趋势,或者呈现数据的整体和局部之间的相互关系,相较于大篇幅的文本数据,图表更增加了我们分析数据时选择的多样性,是我们挖掘数据背后潜在价值的一种更为有效地方式. ...