Ocelot入门实践

博主是第一次写技术文档,一是对这两年工作以来的一些技术和经验进行整理,二也是希望能和大家多多分享交流,如有写的不对的地方望大家多多指正。进入正题


 

Ocelot 概念就不说了,大家自行百度,今天做一个Ocelot实例

 

1.VS新建空白解决方案

 

2.右键解决方案新建项目Service1,Service2选择Api项目模板

 

右键解决方案添加项目Gateway选择空项目模板

 

建立完成后解决方案如下

3.右键解决方案=>设置启动项目

 

打开Service1 launchSettings.json文件,修改"applicationUrl": "http://localhost:7001" ,"launchBrowser": false,

打开Service2 launchSettings.json文件,修改"applicationUrl": "http://localhost:7002" ,"launchBrowser": false,

打开Gateway launchSettings.json文件,修改"applicationUrl": "http://localhost:7000" ,"launchBrowser": false,

 

 4.打开Service1 中 ValuesController改为如下:

 1 using System;
 2 using System.Collections.Generic;
 3 using System.Linq;
 4 using System.Threading.Tasks;
 5 using Microsoft.AspNetCore.Mvc;
 6 
 7 namespace Service1.Controllers
 8 {
 9     [Route("api/[controller]")]
10     [ApiController]
11     public class ValuesController : ControllerBase
12     {
13         // GET api/values
14         [HttpGet]
15         public ActionResult<string> Get()
16         {
17             return "这是 Service1 ";
18         }
19 
20     }
21 }

 

 

 打开Service2 中 ValuesController改为如下:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Threading.Tasks;
using Microsoft.AspNetCore.Mvc;

namespace Service2.Controllers
{
    [Route("api/[controller]")]
    [ApiController]
    public class ValuesController : ControllerBase
    {
        // GET api/values
        [HttpGet]
        public ActionResult<string> Get()
        {
            return "这是 Service2 ";
        }
    }
}

 

5. VS =>调试=>开始执行

打开postman api测试工具 请求 http://localhost:7001/api/values

 

 

请求 http://localhost:7002/api/values

 

 

service准备完毕,接下来接入Ocelot

6.Gateway项目安装nuget包 Install-Package Ocelot

 

Gateway项目下添加ocelot.json文件,右键属性,如果较新则复制,并进行如下配置 

{
  "ReRoutes": [
    {
      //Upstream表示上游请求,即客户端请求到API Gateway的请求
      "UpstreamPathTemplate": "/Service1/{url}", //请求路径模板
      "UpstreamHttpMethod": [ "Get", "Post" ], //请求方法数组

      "UseServiceDiscovery": false, //启用服务发现

      //Downstream表示下游请求,即API Gateway转发的目标服务地址
      "DownstreamPathTemplate": "/api/{url}", //下游请求地址模板
      "DownstreamScheme": "http", //请求协议,支持http,https,ws
      "DownstreamHostAndPorts": [ //请求服务地址
        {
          "Host": "localhost",
          "Port": 7001
        }
      ]
    },
    {
      "UpstreamPathTemplate": "/Service2/{url}",
      "UpstreamHttpMethod": [ "Get", "Post" ],

      "UseServiceDiscovery": false,

      "DownstreamPathTemplate": "/api/{url}",
      "DownstreamScheme": "http",
      "DownstreamHostAndPorts": [
        {
          "Host": "localhost",
          "Port": 7002
        }
      ]
    }
  ],
  "GlobalConfiguration": {
    //"ServiceDiscoveryProvider": {
    //  "Host": "127.0.0.1",
    //  "Port": 8500,
    //  "Type": "PollConsul"
    //}
  }
}

 打开Program.cs,修改如下:

public class Program
    {
        public static void Main(string[] args)
        {
            CreateWebHostBuilder(args).Build().Run();
        }

        public static IWebHostBuilder CreateWebHostBuilder(string[] args) =>
            WebHost.CreateDefaultBuilder(args)
            .ConfigureAppConfiguration((hostingContext, builder) =>
            {
                builder.SetBasePath(hostingContext.HostingEnvironment.ContentRootPath)
                .AddJsonFile("ocelot.json", false, true);
            })
            .UseStartup<Startup>();
    }

打开Startup.cs文件,进行如下配置:

public void ConfigureServices(IServiceCollection services)
        {
            services.AddOcelot();//添加Ocelot服务
        }
public void Configure(IApplicationBuilder app, IHostingEnvironment env)
        {
            if (env.IsDevelopment())
            {
                app.UseDeveloperExceptionPage();
            }

            app.UseOcelot().Wait();//使用Ocelot服务
        }

Ocelot配置完毕,VS=>调试=>开始执行

打开postman工具进行测试

 

请求 http://localhost:7000/Service1/values

 

请求 http://localhost:7000/Service2/values

 

OK!打完收工

转载于:https://www.cnblogs.com/maxne/p/10542031.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Ocelot 提供了 AddDelegatingHandler 方法,用于在 Ocelot 网关中添加委托处理程序(Delegating Handler)。Delegating Handler 是一个用于处理 HTTP 请求和响应的中间件,类似于 ASP.NET Core 中的中间件,但是它是基于委托模式实现的,可以实现更加灵活的请求处理逻辑。 使用 AddDelegatingHandler 方法可以将自定义的委托处理程序添加到 Ocelot 网关中,比如用于鉴权、请求重试等。AddDelegatingHandler 方法的用法如下: ```csharp public void ConfigureServices(IServiceCollection services) { services.AddControllers(); services.AddOcelot().AddDelegatingHandler<MyDelegatingHandler>(); } ``` 其中,MyDelegatingHandler 是自定义的委托处理程序,需要继承 Ocelot.DelegatingHandler.DelegatingHandlerBase 类,并实现其中的 SendAsync 方法。SendAsync 方法是处理 HTTP 请求和响应的核心方法,可以在其中实现自定义的请求处理逻辑。 以下是一个自定义的委托处理程序的示例代码: ```csharp public class MyDelegatingHandler : DelegatingHandlerBase { public MyDelegatingHandler() { } public override async Task<HttpResponseMessage> SendAsync(HttpRequestMessage request, CancellationToken cancellationToken) { // 在此处实现自定义的请求处理逻辑 // ... // 调用下一个处理程序 var response = await base.SendAsync(request, cancellationToken); // 在此处实现自定义的响应处理逻辑 // ... return response; } } ``` 在 SendAsync 方法中,您可以实现自定义的请求处理逻辑,如鉴权、请求重试等,并调用 base.SendAsync 方法调用下一个处理程序。在下一个处理程序调用后,您还可以实现自定义的响应处理逻辑,如统计请求响应时间等。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值