首页 > 其他分享 >Consul 笔记

Consul 笔记

时间:2022-09-18 23:11:26浏览次数:108  
标签:缓存 http url Consul 笔记 -- 地址

Consul

运行Consul

docker run -d -p 8500:8500 --restart=always --name=consul consul:latest agent -server -bootstrap -ui -node=1 -client='0.0.0.0'

API的代码



using Consul;
using Newtonsoft.Json;

var builder = WebApplication.CreateBuilder(args);

builder.Services.AddControllers();
builder.Services.AddEndpointsApiExplorer();
builder.Services.AddSwaggerGen(); 

var app = builder.Build();

app.UseSwagger();
app.UseSwaggerUI();

// 传参是为了告诉consul自己的 host 和 port
// 这里我是直接取执行的参数,可以自己换别的形式通知到应用自己的host和port。
if (!string.IsNullOrWhiteSpace(args[0]) && !string.IsNullOrWhiteSpace(args[1]) && !string.IsNullOrWhiteSpace(args[2]))
{
    var name = args[0];
    var host = args[1];
    var port = int.Parse(args[2]);


    var consulClient = new ConsulClient(options =>
    {
        options.Address = new Uri($"http://wosperry.com.cn:8500/");
        options.Datacenter = "dc1";
    });
    var httpCheck = new AgentServiceCheck()
    {
        DeregisterCriticalServiceAfter = TimeSpan.FromSeconds(5),//服务启动多久后注册
        Interval = TimeSpan.FromSeconds(10),//健康监测
        HTTP = string.Format($"http://{host}:{port}/api/health"),//心跳检测地址
        Timeout = TimeSpan.FromSeconds(5)
    };

    Console.WriteLine(JsonConvert.SerializeObject(httpCheck));

    //注册
    var registrtion = new AgentServiceRegistration()
    {

        Checks = new[] { httpCheck },
        ID = "perry-" + Guid.NewGuid().ToString(),//服务编号不可重复
        Name = name,//服务名称
        Address = host,//ip地址
        Port = port//端口
    };
    //注册服务
    consulClient.Agent.ServiceRegister(registrtion);
}

app.MapGet("api/health", () => { });

app.UseHttpsRedirection();

app.UseAuthorization();

app.MapControllers();

app.Run();

 

Docker 拉代码、构建、运行 API


# docker镜像名字
IMAGE=perry20220918
# 服务名字(Consul用的)
NAME=perry-test
# API 应用自己的Host
HOST=http://wosperry.com.cn
# API 应用自己的端口,给docker,并传到ENTRYPOINT 给dotnet cli 用
# 这个$1是因为我不想手动一次次复制,就定义了一个update.sh文件,通过 ./update.sh 8001 把端口当成参数给到命令里。
# (如果Linux不能执行,可以 chmod 777 update.sh 给全部权限
PORT=$1  
# 这里的几个参数其实是我用代码写的 args[0] 这样获取的,可以换别的形式传

# 下面是真正的命令,就移除掉 容器、镜像,然后拉代码,重新构建镜像,然后运行到指定的端口
docker rm -f ${NAME}-${PORT}
docker rmi -f ${IMAGE}
git pull
docker build -t ${IMAGE} -f Perry20220918/Dockerfile .  
docker run -d -p ${PORT}:80 --name ${NAME}-${PORT} ${IMAGE} ${NAME} ${HOST} ${PORT}

Ocelot的配置

{
  "Routes": [
    {
      //转发到下游服务地址--url变量
      "DownstreamPathTemplate": "/{url}",
      //下游http协议
      "DownstreamScheme": "http",
      //负载方式,
      "LoadBalancerOptions": {
        "Type": "RoundRobin" // 轮询 RoundRobin  最少连接 LeastConnection
      },
      //上游地址
      "UpstreamPathTemplate": "/serviceA/{url}", //网关地址--url变量   //冲突的还可以加权重Priority
      "UpstreamHttpMethod": [ "GET", "POST", "DELETE", "PUT" ],
      "UseServiceDisConvery": true, //使用服务发现
      "ServiceName": "perry-test", //Consul服务名称
      //缓存设置
      "FileCacheOptions": {
        "TtlSeconds": 10, //缓存10s(同一个地址请求就返回缓存结果)
        "Region": "" //缓存region
      }
    },

    {
      //转发到下游服务地址--url变量
      "DownstreamPathTemplate": "/{url}",
      //下游http协议
      "DownstreamScheme": "http",
      //负载方式,
      "LoadBalancerOptions": {
        "Type": "RoundRobin" // 轮询
      },
      //上游地址
      "UpstreamPathTemplate": "/serviceB/{url}", //网关地址--url变量   //冲突的还可以加权重Priority
      "UpstreamHttpMethod": [ "GET", "POST", "DELETE", "PUT" ],
      "UseServiceDisConvery": true, //使用服务发现
      "ServiceName": "hahaha", //Consul服务名称
      //缓存设置
      "FileCacheOptions": {
        "TtlSeconds": 10, //缓存10s(同一个地址请求就返回缓存结果)
        "Region": "" //缓存region
      }
    },

    {
      //转发到下游服务地址--url变量
      "DownstreamPathTemplate": "/{url}",
      //下游http协议
      "DownstreamScheme": "http",
      //负载方式,
      "LoadBalancerOptions": {
        "Type": "RoundRobin" // 轮询
      },
      //上游地址
      "UpstreamPathTemplate": "/serviceC/{url}", //网关地址--url变量   //冲突的还可以加权重Priority
      "UpstreamHttpMethod": [ "GET", "POST", "DELETE", "PUT" ],
      "UseServiceDisConvery": true, //使用服务发现
      "ServiceName": "PTEST", //Consul服务名称
      //缓存设置
      "FileCacheOptions": {
        "TtlSeconds": 10, //缓存10s(同一个地址请求就返回缓存结果)
        "Region": "" //缓存region
      }
    }
  ],
  "GlobalConfiguration": {
    //Ocelot应用地址
    "BaseUrl": "http://localhost:5096",
    "ServiceDiscoveryProvider": {
      //Consul地址
      "Host": "wosperry.com.cn",
      //Consul端口
      "Port": 8500,
      "Type": "Consul" //由Consul提供服务发现,每次请求Consul
    }
  }
}

consul api读取服务列表: https://www.jianshu.com/p/d35cd527d5fb
官方文档: https://ocelot.readthedocs.io/en/latest/features/servicediscovery.html
腾讯云文档《.NET 5 中使用 Consul+Ocelot+Polly缓存、限流、熔断、降级》: https://cloud.tencent.com/developer/article/1899794

标签:缓存,http,url,Consul,笔记,--,地址
From: https://www.cnblogs.com/wosperry/p/16706212.html

相关文章

  • 《汇编指令》-学习笔记-4
    注:本文档为“《汇编语言(第3版)》王爽著”阅读过程中记的笔记。参考视频:通俗易懂的汇编语言(王爽老师的书)_哔哩哔哩_bilibili12内中断中断信息可以来自CPU的内部和外部......
  • 20201302姬正坤第十章学习笔记
    第三周学习笔记第十章第十章的主要内容是研究sh编程。对于sh编程的介绍分为以下几个方面:sh脚本与C程序sh脚本的编写sh控制语句sh汉书知识点归纳:经过一整章的......
  • 《信息安全系统设计与实现学习笔记3》
    一、知识点归纳以及自己最有收获的内容1、知识点归纳总结一下一门程序设计语言有哪些必备的要素和技能?这些要素和技能在shell脚本中是如果呈现出来的?程序设计语言有3个......
  • 第十章学习笔记
    第十章的主要内容是sh编程,包括以下几个方面:sh脚本和不同版本sh比较了sh脚本和C程序sh变量、sh语句、sh内置命令、常规系统命令和命令替换sh控制语句sh函数编写以及使......
  • 第三周学习笔记.
    第十章sh编程概要阐述了sh脚本和不同版本的sh;比较了sh脚本与C程序,并指出了解释语言和编译语言的区别;如何编写sh脚本,包括sh变量、sh语句、sh内置命令、常规系统命令和......
  • CSS笔记
    ①CSS引入方式1)(最常用)在<head>元素下引入:【<link rel="stylesheet"href="xx.css">】3)在CSS文件中导入【@importurl(xx.css)】(语句需写在css文件的开头)3)在style......
  • 第十章笔记
     ......
  • 20201306吴龙灿第十章学习笔记
    知识点归纳这一章的主要内容包含了sh编程的绝大部分内容。但是在此之前,还是要强调一下诸如Python、C、Java这些程序语言的特点。1.Python(一)Python是什么?Python是一......
  • Redis详细教程笔记
    1.目录2.待更新:集群环境搭建、订阅发布、哨兵机制、主从复制、缓存雪崩与穿透3.笔记链接:https://t.wss.ink/f/9bktugzrk5n复制链接到浏览器打开(过期联系:QQ:8108062......
  • 软件需求分析与系统设计笔记
    软件需求分析与系统设计笔记简介什么是软件?软件是计算机系统中与硬件(hardware)相互依存的另一部分,是程序、支持程序运行的数据以及与程序有关的文档的完整集合。......