Easy-DotNET Easy-DotNET
🏠首页
  • 知识地图
  • 源码脑图

    • 总览
    • Program
    • WebApplication
    • Host主机
    • WebHost主机
    • 依赖注入
    • Autofac
    • Middleware中间件
    • RateLimiter限制速率
    • 响应缓存、请求解压缩
  • 设计初衷
  • 克隆
  • 类型转换
  • 日期时间
  • IO流
  • 工具类
  • 语言特性
  • 集合类
  • Codec编码
  • 文本操作
  • 数学
  • 图片
  • 网络
  • Emoji表情
  • C# 12
  • C# 11
  • C# 10
  • C# 9.0
  • C# 8.0
  • C# 早期版本
  • C# 教程
  • ORM
  • 定时任务
  • 日志
  • 认证与授权
  • Swagger
  • 对象映射
  • 熔断重试限流
  • 缓存
  • 注册发现
  • 网关
  • GraphQL
  • 更多
  • Docker

    • 简介
    • Adminer
    • Apisix
    • Apollo
    • Cassandra
    • Cerebro
    • ClickHouse
    • Consul
    • EasyMock
    • Elasticsearch
    • Emqx
    • FastDFS
    • Flink
    • Gitlab
    • Jenkins
    • Jrebel
    • MariaDB
    • MySQL
    • Percona
    • Phpmyadmin
    • PostgreSQL
    • Redis
  • Linux

    • 查看Linux系统信息
    • CentOS7调整磁盘分区
    • IO压测
    • 图形化监控工具Cockpit
  • 总览
  • 列表

    • 算法数据结构
    • API
    • 应用框架
    • 应用模板
    • 操作系统
    • 工作流
    • 入门套件
    • 示例
    • 人工智能
    • 程序集
    • Assets
    • 认证授权
    • Blazor
    • 区块链
    • 书籍
    • 自动构建
    • 报表
    • 缓存
    • 日历
    • 聊天
    • CLI
    • CLR
    • CMS
    • 代码分析和指标
    • 代码片段
    • 压缩
    • 持续集成
    • 密码学
    • 数据库
    • 数据库驱动
    • 日期时间
    • 反编译
    • 部署
    • DirectX
    • 分布式计算
    • DLR
    • 文档
    • 电商支付
    • 模拟器
    • 环境管理
    • ETL
    • 事件消息
    • Exception
    • 扩展
    • 函数式编程
    • 游戏引擎
    • GIS
    • Git工具
    • 绘图
    • GraphQL
    • GUI
    • HTML-CSS
    • HTTP
    • IDE
    • 图片处理
    • 安装工具
    • 交互式编程
    • 国际化
    • 互操作性
    • IoC
    • JS引擎
    • 日志
    • 机器学习和数据科学
    • Markdown
    • 邮件
    • 数学
    • 媒体
    • 指标
    • 微型框架
    • 最小化器
    • MVVM
    • 网络
    • 对象映射
    • Office
    • OpenAI
    • ORM
    • 包管理器
    • PDF
    • 性能分析工具
    • 协议
    • 推送通知
    • SQL构建器
    • 消息队列
    • RPC
    • 响应式编程
    • 实时通信
    • 正则表达式
    • 任务调度
    • SDK和API
    • 搜索引擎
    • 序列化
    • SMS
    • 状态机
    • 静态站点生成
    • 强命名
    • 风格指南
    • 模板引擎
    • 测试
    • 工具
    • 交易
    • UI自动测试
    • Visual Studio 插件
    • Web浏览器
    • Web框架
    • WebServers
    • WebSocket
    • Windows服务
    • WPF
    • 解析器
    • 源码生成
    • 其他
    • 资源
  • AspNetCore面试题
  • Elasticsearch面试题
  • MongoDB面试题
  • MySql面试题
  • Nginx面试题
  • RabbitMQ面试题
  • Redis面试题
  • 设计模式
  • 微服务
🧑‍💻.NET Blog
GitHub (opens new window)
🏠首页
  • 知识地图
  • 源码脑图

    • 总览
    • Program
    • WebApplication
    • Host主机
    • WebHost主机
    • 依赖注入
    • Autofac
    • Middleware中间件
    • RateLimiter限制速率
    • 响应缓存、请求解压缩
  • 设计初衷
  • 克隆
  • 类型转换
  • 日期时间
  • IO流
  • 工具类
  • 语言特性
  • 集合类
  • Codec编码
  • 文本操作
  • 数学
  • 图片
  • 网络
  • Emoji表情
  • C# 12
  • C# 11
  • C# 10
  • C# 9.0
  • C# 8.0
  • C# 早期版本
  • C# 教程
  • ORM
  • 定时任务
  • 日志
  • 认证与授权
  • Swagger
  • 对象映射
  • 熔断重试限流
  • 缓存
  • 注册发现
  • 网关
  • GraphQL
  • 更多
  • Docker

    • 简介
    • Adminer
    • Apisix
    • Apollo
    • Cassandra
    • Cerebro
    • ClickHouse
    • Consul
    • EasyMock
    • Elasticsearch
    • Emqx
    • FastDFS
    • Flink
    • Gitlab
    • Jenkins
    • Jrebel
    • MariaDB
    • MySQL
    • Percona
    • Phpmyadmin
    • PostgreSQL
    • Redis
  • Linux

    • 查看Linux系统信息
    • CentOS7调整磁盘分区
    • IO压测
    • 图形化监控工具Cockpit
  • 总览
  • 列表

    • 算法数据结构
    • API
    • 应用框架
    • 应用模板
    • 操作系统
    • 工作流
    • 入门套件
    • 示例
    • 人工智能
    • 程序集
    • Assets
    • 认证授权
    • Blazor
    • 区块链
    • 书籍
    • 自动构建
    • 报表
    • 缓存
    • 日历
    • 聊天
    • CLI
    • CLR
    • CMS
    • 代码分析和指标
    • 代码片段
    • 压缩
    • 持续集成
    • 密码学
    • 数据库
    • 数据库驱动
    • 日期时间
    • 反编译
    • 部署
    • DirectX
    • 分布式计算
    • DLR
    • 文档
    • 电商支付
    • 模拟器
    • 环境管理
    • ETL
    • 事件消息
    • Exception
    • 扩展
    • 函数式编程
    • 游戏引擎
    • GIS
    • Git工具
    • 绘图
    • GraphQL
    • GUI
    • HTML-CSS
    • HTTP
    • IDE
    • 图片处理
    • 安装工具
    • 交互式编程
    • 国际化
    • 互操作性
    • IoC
    • JS引擎
    • 日志
    • 机器学习和数据科学
    • Markdown
    • 邮件
    • 数学
    • 媒体
    • 指标
    • 微型框架
    • 最小化器
    • MVVM
    • 网络
    • 对象映射
    • Office
    • OpenAI
    • ORM
    • 包管理器
    • PDF
    • 性能分析工具
    • 协议
    • 推送通知
    • SQL构建器
    • 消息队列
    • RPC
    • 响应式编程
    • 实时通信
    • 正则表达式
    • 任务调度
    • SDK和API
    • 搜索引擎
    • 序列化
    • SMS
    • 状态机
    • 静态站点生成
    • 强命名
    • 风格指南
    • 模板引擎
    • 测试
    • 工具
    • 交易
    • UI自动测试
    • Visual Studio 插件
    • Web浏览器
    • Web框架
    • WebServers
    • WebSocket
    • Windows服务
    • WPF
    • 解析器
    • 源码生成
    • 其他
    • 资源
  • AspNetCore面试题
  • Elasticsearch面试题
  • MongoDB面试题
  • MySql面试题
  • Nginx面试题
  • RabbitMQ面试题
  • Redis面试题
  • 设计模式
  • 微服务
🧑‍💻.NET Blog
GitHub (opens new window)
npm
  • 简介
  • ORM

    • EFCore
    • Dapper
    • FreeSql
    • SqlSugar
  • 任务调度

    • Hangfire
    • Quartz
    • FluentScheduler
    • Coravel
    • Quartzmin
  • 日志

    • Serilog
    • NLog
    • Log4Net
    • Stackdriver
    • ExceptionLess
  • 身份认证与授权

    • IdentityServer4
    • Identity
    • JWTBearer
    • Auth0
    • OpenIddict
  • Swagger文档

    • Swagger
    • Swashbuckle
    • NSwag
    • ReDoc
  • 对象映射

    • AutoMapper
    • EmitMapper
    • AgileMapper
    • Mapster
  • 消息传递

    • MediatR
    • MassTransit
    • Rebus
    • NServiceBus
  • 熔断重试限流

    • Polly
    • Resilience4j
    • AkkaNET
  • 缓存

    • CsRedis
    • FreeRedis
    • EasyCaching
    • StackExchangeRedis
    • CacheCow
    • NCache
    • Memory
  • 注册发现

    • Consul
      • 安装 Consul
      • 注册服务
      • 发现服务
      • 使用 Consul KV 存储
      • 结论
    • Nacos
    • Apollo
  • 网关

    • Ocelot
    • Kong
    • Traefik
    • Zuul
  • GraphQL

    • GraphQLPlatform
    • GraphQLdotnet
  • 更多

    • NodaTime
    • FluentAssertions
    • Humanizer
    • 爬虫-AngleSharp
    • 邮件-MailKit
  • NET微服务
  • 注册发现
一个大西瓜
2023-04-25
目录

Consul

开源地址

Github:https://github.com/G-Research/consuldotnet (opens new window)

Consul 是一个分布式服务发现和配置管理系统,由 HashiCorp 开发。它提供了服务发现、健康检查、KV 存储、多数据中心支持等功能,可以帮助我们构建高可用、可扩展的微服务架构。在 .NET 生态系统中,我们可以通过 Consul SDK 来使用 Consul。

本文将介绍 .NET 中 Consul 的使用,包括如何安装 Consul,如何注册服务和发现服务,如何使用 Consul KV 存储等。

# 安装 Consul

我们可以通过下载 Consul 的二进制文件来安装 Consul,也可以通过包管理工具来安装。在 Windows 上,我们可以下载最新版本的 Consul Windows 安装包并安装,也可以使用 Chocolatey 包管理工具来安装:


choco install consul

在 Linux 上,我们可以下载最新版本的 Consul Linux 安装包并安装,也可以使用包管理工具来安装:


sudo apt-get update && sudo apt-get install consul

安装完成后,我们可以通过运行 consul version 命令来查看 Consul 的版本信息。

# 注册服务

要使用 Consul 进行服务注册,我们需要创建一个 Consul 客户端对象,然后使用该客户端对象来注册服务。在 .NET 中,我们可以使用 Consul SDK 来创建客户端对象。

以下是一个使用 Consul SDK 注册服务的示例:


using Consul;

var client = new ConsulClient();
var registration = new AgentServiceRegistration()
{
    ID = "my-service-1",
    Name = "my-service",
    Address = "localhost",
    Port = 8080
};
client.Agent.ServiceRegister(registration).Wait();

上述代码创建了一个 Consul 客户端对象,并注册了一个名为 my-service 的服务,该服务的地址为 localhost:8080。

在注册服务时,我们可以指定一些元数据,例如版本号、标签等。以下是一个示例:


var registration = new AgentServiceRegistration()
{
    ID = "my-service-1",
    Name = "my-service",
    Address = "localhost",
    Port = 8080,
    Meta = new Dictionary<string, string>()
    {
        { "version", "1.0.0" },
        { "tags", "api,gateway" }
    }
};

要注销服务,我们可以使用 client.Agent.ServiceDeregister 方法:


client.Agent.ServiceDeregister("my-service-1").Wait();

# 发现服务

要使用 Consul 进行服务发现,我们可以使用 Consul SDK 提供的查询 API 来查询服务。以下是一个查询服务的示例:


using Consul;

var client = new ConsulClient();
var services = client.Agent.Services().Result.Response.Values;
var myService = services.FirstOrDefault(s => s.Service == "my-service");
if (myService != null)
{
    var address = $"http://{myService.Address}:{myService.Port}";
    Console.WriteLine($"Found my-service at {address}");
}
else
{
    Console.WriteLine("my-service not found");
}

上述代码创建了一个 Consul 客户端对象,并使用 client.Agent.Services() 方法查询所有已注册的服务。然后,我们可以使用 LINQ 查询语句从结果中找到名为 my-service 的服务,并获取其地址和端口号。如果找到了该服务,就可以使用其地址和端口号来访问该服务。

当我们使用 Consul 进行服务发现时,通常会使用一个负载均衡器来将请求路由到不同的服务实例。Consul SDK 提供了一些负载均衡策略,例如随机、轮询、加权轮询等。以下是一个使用随机负载均衡策略的示例:


using Consul;

var client = new ConsulClient();
var services = client.Agent.Services().Result.Response.Values;
var myServices = services.Where(s => s.Service == "my-service");
var endpoint = new RandomEndpointStrategy().Select(myServices).ServiceEndpoint;
var address = $"http://{endpoint.Address}:{endpoint.Port}";
Console.WriteLine($"Found my-service at {address}");

上述代码首先查询所有已注册的服务,然后使用 LINQ 查询语句找到名为 my-service 的所有服务。接下来,我们使用 RandomEndpointStrategy 负载均衡策略从这些服务中随机选择一个服务实例,并获取其地址和端口号。

除了使用 Consul SDK 进行服务发现外,我们还可以使用 Consul 的 HTTP API 进行服务发现。以下是一个使用 HTTP API 查询服务的示例:


using System.Net.Http;
using System.Threading.Tasks;
using Newtonsoft.Json.Linq;

var client = new HttpClient();
var response = await client.GetAsync("http://localhost:8500/v1/catalog/service/my-service");
var content = await response.Content.ReadAsStringAsync();
var services = JArray.Parse(content);
if (services.Count > 0)
{
    var service = services.First();
    var address = $"http://{service["Address"]}:{service["ServicePort"]}";
    Console.WriteLine($"Found my-service at {address}");
}
else
{
    Console.WriteLine("my-service not found");
}

上述代码使用 HttpClient 类发送一个 HTTP GET 请求到 Consul 的 /v1/catalog/service/my-service 路径,以查询名为 my-service 的服务。然后,我们解析响应内容并获取第一个服务实例的地址和端口号。如果找到了该服务,就可以使用其地址和端口号来访问该服务。

# 使用 Consul KV 存储

除了服务发现和配置管理外,Consul 还提供了 KV 存储功能,可以帮助我们存储和管理应用程序的配置信息、秘密信息等。在 .NET 中,我们可以使用 Consul SDK 提供的 KV 存储 API 来访问 Consul KV 存储。

以下是一个使用 Consul SDK 访问 KV 存储的示例:


using Consul;

var client = new ConsulClient();
var key = "myapp/config/database";
var value = "Server=localhost;Database=myapp;User ID=myuser;Password=mypassword;";
await client.KV.Put(new KVPair(key) { Value = Encoding.UTF8.GetBytes(value) });
var queryResult = await client.KV.Get(key);
var storedValue = Encoding.UTF8.GetString(queryResult.Response.Value);
Console.WriteLine($"Stored value for {key}: {storedValue}");

上述代码创建了一个 Consul 客户端对象,并使用 client.KV.Put 方法将一个键值对存储到 Consul KV 存储中。然后,我们使用 client.KV.Get 方法获取该键的值,并将其输出到控制台。

要删除一个键值对,我们可以使用 client.KV.Delete 方法:

await client.KV.Delete(key);

在实际使用中,我们可能需要将多个配置项存储到 Consul KV 存储中。为了方便管理,我们可以使用层次结构来组织这些配置项。以下是一个使用层次结构组织配置项的示例:


var config = new Dictionary<string, string>()
{
    { "database/server", "localhost" },
    { "database/name", "myapp" },
    { "database/user", "myuser" },
    { "database/password", "mypassword" }
};
foreach (var item in config)
{
    var key = $"myapp/config/{item.Key}";
    var value = item.Value;
    await client.KV.Put(new KVPair(key) { Value = Encoding.UTF8.GetBytes(value) });
}

上述代码将多个配置项存储到 Consul KV 存储中,并使用 myapp/config 前缀来组织这些配置项。这样,我们可以轻松地管理这些配置项,而无需将它们存储在不同的位置。

在读取配置时,我们可以使用 Consul SDK 提供的递归查询功能来获取指定前缀下的所有键值对。以下是一个查询指定前缀下的所有键值对的示例:


var prefix = "myapp/config";
var queryResult = await client.KV.List(prefix);
var config = queryResult.Response
    .Where(p => p.Value != null)
    .ToDictionary(p => p.Key.Remove(0, prefix.Length + 1), p => Encoding.UTF8.GetString(p.Value));
foreach (var item in config)
{
    Console.WriteLine($"{item.Key}: {item.Value}");
}

上述代码使用 client.KV.List 方法查询以 myapp/config 前缀开头的所有键值对。然后,我们将查询结果转换为一个字典,并将其输出到控制台。

# 结论

本文介绍了如何在 .NET 中使用 Consul 进行服务注册和发现、配置管理等。我们使用 Consul SDK 提供的 API 和 Consul 的 HTTP API 来访问 Consul,实现了服务发现和配置管理等功能。如果你正在构建微服务架构,并希望使用分布式服务发现和配置管理系统,那么 Consul 将是一个不错的选择。

上次更新: 2023/04/26, 22:10:06
Memory
Nacos

← Memory Nacos→

Theme by Vdoing | Copyright © 2019-2024 一个大西瓜 | MIT License | 苏ICP备2023013501号
  • 跟随系统
  • 浅色模式
  • 深色模式
  • 阅读模式