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

简介

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

特点

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

配置示例

配置遵循 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