CondenserDotNet - 使用 Kestrel 和 Consul 的 API 反向代理库!

简介

CondenserDotNet - 使用 Kestrel 和 Consul 的 API 反向代理库!

特点

•Consul 客户端库,包括服务注册、发现和配置•反向代理•交互式 UI,用于查看有关代理的统计信息19f68eb1ca5b20bf73161753943afa28.png

配置示例

配置遵循 LIFO 策略,以最后注册的配置为准

var configValue = configRegistry["MyKey"];

如果密钥不存在,它将引发异常。您也可以使用普通的 tryget 模式访问它

if(configRegistry.TryGetValue("MyKey", out string configValue))
{
    //do something with the key
}

静态配置

要注册一组静态键,请使用以下代码

var result = await configRegistry.AddStaticKeyPathAsync("my/keys/path");

动态配置

可以注册动态配置的关键路径,代码如下

var registry = new ConsulRegistry();
    await registry.AddUpdatingPathAsync("org/test5/");

还可以注册回调以提醒您是否更新了特定键或配置中的任何键是否已更新。

var singleCallBack = registry.AddWatchOnSingleKey("test1", () => Console.Writeline("Key Changed!");

如果您想要任何更新来触发您的回调,只需执行

var multipleCallBack = registry.AddWatchOnEntireConfig(
    () => Console.Writeline("Some key changed, or multiple keys changed, or maybe none?");

请求服务

获取要连接的服务实例的示例

var serviceInstance = await serviceRegistry.GetServiceInstanceAsync("ServiceLookup");
if(serviceInsance == null)
{
    //you need to handle no service instance available
}
//connect to service via your method
var serverUrl = $"http://{serviceInstance.Address}:{serviceInsance.Port}";

//your method for calling servers

服务端口

在动态端口上配置 Kestrel 的示例

var host = new WebHostBuilder()
    .UseKestrel()
    .UseUrls($"http://*:{ServiceManagerOptions.GetNextAvailablePort()}")
    .UseStartup<Startup>()
    .Build();

host.Run();

服务注册

在动态端口上配置 Kestrel 的示例

var host = new WebHostBuilder()
    .UseKestrel()
    .UseUrls($"http://*:{serviceManager.ServicePort}")
    .UseStartup<Startup>()
    .Build();

host.Run();

Github地址

https://github.com/Drawaes/CondenserDotNet

最后大家如果喜欢我的文章,还麻烦给个关注并点个赞, 希望net生态圈越来越好!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值