在新版本的服务网关中提供了服务发现和泛域名路由解决功能,服务发现可以在无须配置的情况下实现服务自动注册到网关中解脱对服务配置的繁琐工作;而泛域名路由则可以针对不同的域名制定不同的负载规则。

使用consul服务发现插件

网关需要维护相关负载的服务器,手动添加相对来说是一件比较麻烦的工作;为了解决这一问题组件扩展了一个基于consul服务发现插件,通过配置这个插件和启用后网关会自动从consul服务中获取服务并添加到网关对应的路由负载规则中。

引用插件

Bumblebee中使用服务发现需要引用两个插件,分别是BeetleX.Bumblebee.ConfigurationBeetleX.Bumblebee.BeetleX.Bumblebee.Consul。加载启动后就可以通过管理工具进行插件配置.

复制代码
            g = new Gateway();             g.HttpOptions(                 o =>                 {                     o.Port = 80;                     o.LogToConsole = true;                     o.LogLevel = BeetleX.EventArgs.LogType.Error;                 });             g.Open();             g.LoadPlugin(                 typeof(Bumblebee.Configuration.Management).Assembly,                 typeof(Bumblebee.Consul.ConsulPlugin).Assembly                );
复制代码

如果不想自己编写代码可以下载编译的运行包 https://github.com/IKende/Bumblebee/blob/master/bin/ 下载1.1.9或更高版本;运行后 访问 http://host/__system/bumblebee/

插件管理

运行程序后进行配置管理工具的插件管理页面,可以看到Consul插件,组件默认是关闭需要进行一些配置。

插件配置

复制代码
{     "ConsulAddress": "http://192.168.2.19:8500",     "Services": [         "bumblebee_services"     ],     "Token": null,     "DataCenter": "dc1" }
复制代码
  • ConsulAddress 对应Consul的服务地址
  • Services 检索相应名称的服务列表一个或多个
  • Token 访问Consul相应的Token信息
  • DataCenter 检索相应的数据中心名称

配置完成后只需要启用插件即可

注册要求

复制代码
Dictionary<string, string> meta = new Dictionary<string, string>(); meta.Add("path", "^/home.*"); client.Agent.ServiceDeregister(