码迷,mamicode.com
首页 > 其他好文 > 详细

Ocelot学习笔记

时间:2017-08-29 12:45:15      阅读:94      评论:0      收藏:0      [点我收藏+]

标签:ati   集合   依次   ups   path   install   路由配置   扩展   注册   

 

  最近因工作需要,开始学习Ocelot。首先简单介绍一下,Ocelot是一个基于.net core的开源webapi 服务网关项目,目前已经支持了IdentityServer认证。根据 作者介绍,Ocelot本质上是一堆中间件的集合,当HttpRequest请求到达后由一堆中间件进行处理,处理完毕,请求根据配置转发给下游服务。然后接受下游服务的返回信息在转发给客户端,详细信息请参考作者给出的文档。

  GitHub地址:https://github.com/TomPallister/Ocelot

  先简单介绍下,如何搭建一个Ocelot项目。

  首先,新建一个基于.net core的webapi项目, core版本要高于或等于1.1,因为目前Ocelot是基于.net core1.1

  然后可以通过nuget安装Ocelot  

Install-Package Ocelot

  至此,项目搭建完毕。下面,在项目中添加 configuration.json 配置文件。Ocelot主要功能都是通过配置项来实现的。首先,我们来实现最简单的服务转发功能。配置文件中有两个配置项,一个是ReRoutes主要的服务路由配置,都配置在此配置项中。一个GlobalConfiguration,全局配置项,一些可应用与全局的配置可放在此配置项中。

  

"ReRoutes": [
    {
      "DownstreamPathTemplate": "/api/values",
      "DownstreamScheme": "http",
      "DownstreamPort": 8052,
      "DownstreamHost": "localhost",
      "UpstreamPathTemplate": "/api/values",
      "UpstreamHttpMethod": [ "Get" ],
      "QoSOptions": {
        "ExceptionsAllowedBeforeBreaking": 3,
        "DurationOfBreak": 10,
        "TimeoutValue": 5000
      }
    },
    {
      "DownstreamPathTemplate": "/api/product",
      "DownstreamScheme": "http",
      "DownstreamPort": 8053,
      "DownstreamHost": "localhost",
      "UpstreamPathTemplate": "/api/product",
      "UpstreamHttpMethod": [ "Get" ],
      "QoSOptions": {
        "ExceptionsAllowedBeforeBreaking": 3,
        "DurationOfBreak": 10,
        "TimeoutValue": 5000
      }
    }
  ],
  "GlobalConfiguration": {
  }

  配置项完毕后,现在需要修改Startup中的代码

  技术分享

  将刚新建的json文件,添加到系统配置项中。然后简单修改一下ConfigureServices和Configure,主要就是将Ocelot作为中间件注册。当然你可以按照自己的需求,做更多的扩展。

  技术分享

    Program.cs 类文件代码

   技术分享

    至此,全部工作已经完成。然后我们新建两个api服务,对应configuration.json文件中的下游服务。

    技术分享

    然后依次启动 apinoe,apitwo,和ServcesGateWay,即可看到结果

    技术分享

    技术分享

 

 

  

Ocelot学习笔记

标签:ati   集合   依次   ups   path   install   路由配置   扩展   注册   

原文地址:http://www.cnblogs.com/dandan123/p/7447372.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!