• 首先下载consul 点击这里下载
  • 转到解压文件夹目录输入cmd命令  consul agent -dev (有时候会卡住按一下方向键上)
  • 在浏览器中输入http://localhost:8500/ui 查看是否安装成功成功如下图所示
  • 在网站启动的时候注册服务,网站停止的时候卸载服务。
  • 服务的注册
    • 先引用consul nuget包
    • 添加配置文件
      {
      ...
      "ServiceDiscovery": {
      "ServiceName": "DataService",
      "Consul": {
      "HttpEndpoint": "http://127.0.0.1:8500",
      "DnsEndpoint": {
      "Address": "127.0.0.1",
      "Port": 8600
      }
      }
      }
      }

       

      public class ServiceDisvoveryOptions
      {
      public string ServiceName { get; set; } public ConsulOptions Consul { get; set; }
      } public class ConsulOptions
      {
      public string HttpEndpoint { get; set; } public DnsEndpoint DnsEndpoint { get; set; }
      } public class DnsEndpoint
      {
      public string Address { get; set; } public int Port { get; set; } public IPEndPoint ToIPEndPoint()
      {
      return new IPEndPoint(IPAddress.Parse(Address), Port);
      }
      }
    • 在网站启动和卸载的时候添加对应注册和卸载事件
         public class Startup
      {
      public Startup(IConfiguration configuration)
      {
      Configuration = configuration;
      } public IConfiguration Configuration { get; }
      // This method gets called by the runtime. Use this method to add services to the container.
      public void ConfigureServices(IServiceCollection services)
      {
      services.AddDbContext<UserContext>(options =>
      {
      options.UseMySQL(Configuration.GetConnectionString("MysqlUser"));
      }); //从配置文件中获取ServiceDiscovery
      services.Configure<ServiceDisvoveryOptions>(Configuration.GetSection("ServiceDiscovery"));
      //单例注册ConsulClient
      services.AddSingleton<IConsulClient>(p => new ConsulClient(cfg =>
      {
      var serviceConfiguration = p.GetRequiredService<IOptions<ServiceDisvoveryOptions>>().Value; if (!string.IsNullOrEmpty(serviceConfiguration.Consul.HttpEndpoint))
      {
      // if not configured, the client will use the default value "127.0.0.1:8500"
      cfg.Address = new Uri(serviceConfiguration.Consul.HttpEndpoint);
      }
      })); services.AddMvc();
      //添加授权相关代码
      services.AddAuthentication(options =>
      {
      options.DefaultAuthenticateScheme = "Cookies";
      options.DefaultChallengeScheme = "oidc";
      })
      .AddCookie("Cookies")
      .AddOpenIdConnect(//配置授权信息相关
      "oidc", options =>
      {
      options.SignInScheme = "Cookies";
      options.Authority = "http://localhost:52619";//授权地址
      options.RequireHttpsMetadata = false;//ssl证书
      options.ResponseType = OpenIdConnectResponseType.CodeIdToken;
      options.ClientId = "MVC";
      options.ClientSecret = "Secret";
      options.SaveTokens = true;
      // options.GetClaimsFromUserInfoEndpoint = true;//发起另外一个请求~52619/content/userInfo 获取userinfo
      //options.ClaimActions.MapJsonKey("sub", "sub");
      //options.ClaimActions.MapJsonKey("preferred_username", "preferred_username");
      //options.ClaimActions.MapJsonKey("sub", "sub");
      //options.ClaimActions.MapJsonKey("avatar", "avatar");
      //options.ClaimActions.MapCustomJson("role", jobject => jobject["role"].ToString());
      options.Scope.Add("geteway_api");
      options.Scope.Add("openid");
      options.Scope.Add("profile");
      options.Scope.Add("offline_access");
      //options.Scope.Add("email"); }
      );//添加
      }
      // This method gets called by the runtime. Use this method to configure the HTTP request pipeline.
      public void Configure(IApplicationBuilder app,
      IHostingEnvironment env,
      ILoggerFactory LoggerFactory,
      IApplicationLifetime lifetime,
      IConsulClient consulClient,
      IOptions<ServiceDisvoveryOptions> DisvoveryOptions)
      {
      if (env.IsDevelopment())
      {
      app.UseDeveloperExceptionPage();
      }
      app.UseMvc();
      app.UseAuthentication(); lifetime.ApplicationStarted.Register(() =>
      {
      RegisterService(app, DisvoveryOptions, consulClient);
      });
      lifetime.ApplicationStopped.Register(() =>
      {
      DeRegisterService(app, DisvoveryOptions, consulClient);
      });
      UserContextSeed.SeedAsync(app, LoggerFactory).Wait();
      //InitUserDataBase(app);//初始化数据库脚本再创建数据库之后取消注释
      }
      //注册服务方法
      private void RegisterService(IApplicationBuilder app,
      IOptions<ServiceDisvoveryOptions> serviceOptions,
      IConsulClient consul)
      {
      //从当前启动的url中拿到url
      var features = app.Properties["server.Features"] as FeatureCollection;
      var addresses = features.Get<IServerAddressesFeature>()
      .Addresses
      .Select(p => new Uri(p)); foreach (var address in addresses)
      {
      var serviceId = $"{serviceOptions.Value.ServiceName}_{address.Host}:{address.Port}"; var httpCheck = new AgentServiceCheck()
      {
      DeregisterCriticalServiceAfter = TimeSpan.FromMinutes(1),
      Interval = TimeSpan.FromSeconds(30),
      HTTP = new Uri(address, "HealthCheck").OriginalString
      }; var registration = new AgentServiceRegistration()
      {
      Checks = new[] { httpCheck },
      Address = address.Host,
      ID = serviceId,
      Name = serviceOptions.Value.ServiceName,
      Port = address.Port
      }; consul.Agent.ServiceRegister(registration).GetAwaiter().GetResult(); }
      }
      //移除方法
      private void DeRegisterService(IApplicationBuilder app,
      IOptions<ServiceDisvoveryOptions> serviceOptions,
      IConsulClient consul)
      {
      //从当前启动的url中拿到url
      var features = app.Properties["server.Features"] as FeatureCollection;
      var addresses = features.Get<IServerAddressesFeature>()
      .Addresses
      .Select(p => new Uri(p)); foreach (var address in addresses)
      {
      var serviceId = $"{serviceOptions.Value.ServiceName}_{address.Host}:{address.Port}";
      consul.Agent.ServiceDeregister(serviceId).GetAwaiter().GetResult();
      }
      } }
  • 服务的发现
    • 添加配置文件(这里关键是ServiceName要对上)

      {
      ...
      "ServiceDiscovery": {
      "ServiceName": "DataService",
      "Consul": {
      "HttpEndpoint": "http://127.0.0.1:8500",
      "DnsEndpoint": {
      "Address": "127.0.0.1",
      "Port": 8600
      }
      }
      }
      }
      public class ServiceDisvoveryOptions
      {
      public string ServiceName { get; set; } public ConsulOptions Consul { get; set; }
      } public class ConsulOptions
      {
      public string HttpEndpoint { get; set; } public DnsEndpoint DnsEndpoint { get; set; }
      } public class DnsEndpoint
      {
      public string Address { get; set; } public int Port { get; set; } public IPEndPoint ToIPEndPoint()
      {
      return new IPEndPoint(IPAddress.Parse(Address), Port);
      }
      }
    • 引用dnsClient nuget包并在ConfigureServices方法中注入相应的实例
               //从配置文件中获取ServiceDiscovery
      services.Configure<ServiceDisvoveryOptions>(Configuration.GetSection("ServiceDiscovery")); services.AddSingleton<IDnsQuery>(p =>
      {
      var serviceConfig = p.GetRequiredService<IOptions<ServiceDisvoveryOptions>>().Value;//从配置文件中获取consul相关配置信息
      return new LookupClient(serviceConfig.Consul.DnsEndpoint.ToIPEndPoint());
      });
    • 根据配置文件信息去consul中获取相应的地址
        private readonly string userServiceUrl = "http://localhost:60907/";
      
              public UserService( IOptions<ServiceDisvoveryOptions> option,IDnsQuery dnsQuery)
      {
      var addrs = dnsQuery.ResolveService("service.consul", option.Value.ServiceName);
      var addressList = addrs.First().AddressList;
      var host = addressList.Any() ? addressList.First().ToString() : addrs.First().HostName;
      var port = addrs.First().Port;
      userServiceUrl = $"http://{host}:{port}";
      }
    • 参考自大佬文章 http://michaco.net/blog/ServiceDiscoveryAndHealthChecksInAspNetCoreWithConsul?tag=Consul

ocelot集成consul服务发现的更多相关文章

  1. Redola.Rpc 集成 Consul 服务发现

    Redola.Rpc 解决了什么问题? Redola.Rpc 是一个使用 C# 开发的 RPC 框架,代码开源在 GitHub 上.目前版本仅支持 .NET Framework 4.6 以上版本,未来 ...

  2. Ocelot 网关 和 consul 服务发现

    服务发现 Consul 一.安装和启动 下载 [Consul](https://www.consul.io/downloads.html) 下载完成后,解压,只有一个consul.exe,把目录添加到 ...

  3. 微服务(入门三):netcore ocelot api网关结合consul服务发现

    简介 api网关是提供给外部调用的统一入口,类似于dns,所有的请求统一先到api网关,由api网关进行指定内网链接. ocelot是基于netcore开发的开源API网关项目,功能强大,使用方便,它 ...

  4. 基于Docker的Consul服务发现集群搭建

    在去年的.NET Core微服务系列文章中,初步学习了一下Consul服务发现,总结了两篇文章.本次基于Docker部署的方式,以一个Demo示例来搭建一个Consul的示例集群,最后给出一个HA的架 ...

  5. .NET Core微服务实施之Consul服务发现与治理

    .NET Core微服务实施之Consul服务发现与治理   Consul官网:https://www.consul.io Consul下载地址:https://www.consul.io/downl ...

  6. .NetCore Cap 注册 Consul 服务发现

    注册服务发现 需要使用Cap中的UseDiscovery方法 具体用法如下 var capConsulConfig = Configuration.GetSection("CapConsul ...

  7. 扩展gRPC支持consul服务发现和Polly策略

    gRPC由于需要用工具生成代码实现,可开发性不是很高,在扩展这方面不是很友好 最近研究了下,进行了扩展,不需要额外的工具生成,直接使用默认Grpc.Tools生成的代理类即可 相关源码在文章底部 客户 ...

  8. 学习搭建 Consul 服务发现与服务网格-有丰富的示例和图片

    目录 第一部分:Consul 基础 1,Consul 介绍 2,安装 Consul Ubuntu/Debian 系统 Centos/RHEL 系统 检查安装 3,运行 Consul Agent 启动 ...

  9. .Net Core微服务——网关(2):ocelot集成consul

    有consul基础的都知道,consul可以发现新增的服务,剔除掉无效的服务,赋予应用自动伸缩的能力.而ocelot如果集成了consul,那ocelot也能拥有这些能力,还可以自主选择负载均衡策略, ...

随机推荐

  1. 什么是IoC和DI?DI是如何实现的?

    IoC叫控制反转,是Inversion of Control的缩写,控制反转是把传统上由程序代码直接操控的对象的调用权交给容器,通过容器来实现对象组件的装配和管理.所谓的"控制反转" ...

  2. iOS的navigationbar设置左边按钮文字

    实例代码: - (void)viewDidLoad { [super viewDidLoad]; [self setTitle:@"Test"]; //以下是主要实现代码 UIBu ...

  3. react浏览器回退按钮的时候传递参数

    本来是有这个需求的,但是后来发现回退不也是到某个页面吗?接下来就使用了redux,真香啊,不管用户怎么操作,你到这个界面都给他一个值就完事了,没有就不给他这个值. 哈哈哈,公司框架使用umi.上代码 ...

  4. HandlerAdapter解析参数过程之HandlerMethodArgumentResolver

    在我们做Web开发的时候,会提交各种数据格式的请求,而我们的后台也会有相应的参数处理方式.SpringMVC就为我们提供了一系列的参数解析器,不管你是要获取Cookie中的值,Header中的值,JS ...

  5. python from…import* 语句

    把一个模块的所有内容全都导入到当前的命名空间也是可行的,只需使用如下声明: from modname import * 这提供了一个简单的方法来导入一个模块中的所有项目.然而这种声明不该被过多地使用. ...

  6. android 小音频频繁播放

    android中多媒体文件(音乐和视频)的播放是用MediaPlayer方式是大家比较熟悉的,但是现在要来说一下另外一种音乐文件播放的方式SoundPool,相比较而言,用MediaPlayer来播放 ...

  7. openwrt boot 启动出现的问题

    一.boot启动出现JFFS2挂载文件系统错误 问题排查: 1.固件问题. 2.刷机,写进去不完整. 3.flash有问题. 二.openwrt 进入web页面出错 解决方法: 1.SSH进去,先恢复 ...

  8. You Are Given a WASD-string...

    C. You Are Given a WASD-string... 主要看的还是思维,分别求出在上下左右四个方向移动的最大幅度( mov_up, mov_down, mov_right, mov_le ...

  9. Unity3D_(Shuriken粒子系统)制作简单的烟花爆炸效果

    Unity中的粒子系统可以用于制作特效,如开枪火花效果,简单爆炸效果等.(毕竟程序员不是设计师,简单的特效都没有问题,要制作一些非常美观的特效还是需要多了解跟美术有关的知识.) 粒子系统实现一个简单的 ...

  10. Jmeter -- 监听 -- 查看每个请求的启动时间等信息

    步骤: 1. 添加监听器 Add --> Listener --> View Results in Table 2. 执行线程组,查看监听信息