• [转载]Ocelot简易教程(六)之重写配置文件存储方式并优化响应数据


    作者:依乐祝
    原文地址:https://www.cnblogs.com/yilezhu/p/9807125.html

    很多人都说配置文件的配置很繁琐,如果存储在数据库就方便很多,可以通过自定义UI界面在后台进行路由的配置,然后通过调用Administration API让修改后的路由规则立即生效。当然这都是后话了。今天就教你手把手的来把配置文件放到数据库中,然后在数据库中进行路由的配置。当然,我会在Github上开放源代码供大家参考。至于Nuget包的话,今天还没来得及弄,等明天晚上弄好,再发布Nuget包吧,今天先引用下源代码来使用吧。大家委屈一下吧。本文还是沿用之前的系列文章里面的Demo。所以可以先下载之前系列文章里面的Demo源码。https://github.com/yilezhu/OcelotDemo

    实例教程集成步骤

    1. Github上下载重写的配置文件的源代码,地址:https://github.com/yilezhu/Ocelot.ConfigAuthLimitCache 然后把项目文件拷贝到。系列文章的源代码下面,并添加项目引用。如下所示:

      1540302626763

    项目添加进来后的结构如下所示:

    1540302716406

    1. OcelotDemo网关项目作如下修改,Programs.cs文件移除对Ocelot.json文件的引用,因为配置文件的获取方式已经改成了从数据库中获取,所以,你需要新建一个数据库,然后执行数据库脚本创建数据库表,这里只给出Mssql的数据库脚本https://github.com/yilezhu/Ocelot.ConfigAuthLimitCache/blob/master/Ocelot.sql ,在项目源代码下面,大家自行下载。

    2. ConfigureServices服务中Ocelot的注入的同时需要注入我们的扩展方法,如下所示:

      services.AddOcelot()//注入Ocelot服务
                          .AddAuthLimitCache(option=> {
                              option.DbConnectionStrings = "Server=.;Database=Ocelot;User ID=sa;Password=1;";
                          })
                          .AddConsul();

      注意:这里需要传入SqlServer的数据库连接字符串,由于博主扩展使用的Dapper+MSSQL所以这里需要传入步骤1中创建的数据库的链接字符串。

    3. 我们在数据库中配置一个路由吧,如下所示:字段名称基本都是跟Ocelot原生配置名称一样,只是扩展了一些字段方便后期做限流的

      1540303270834

      大家看到没有,这条路由的意思是接受/ss1/{通配符} 的路由,然后转到到下面就是/api/{通配符} 。

    4. 路由配置好了,那就让我们启动一下项目看下效果吧。

      1540303513128

    5. 上面是正常的访问结果,当我们访问一个错误的路由的时候,再看看吧。

      1540304187258

      看到没有,返回了404的状态码,感觉不够友好,所以,我们也进行了改造。直接看结果吧

    6. 为了看到效果,你需要在Configure中少做下修改

       app.UseAhphOcelot().Wait();
    7. 然后我们重新启动下Ocelot网关项目,重新访问下6中的Url吧。

      1540304235799

      看到没有,返回的数据更友好,而且是200的状态。当然大家也可以忽略这个功能哈。

    源码地址:

    1. Demo地址:https://github.com/yilezhu/OcelotDemo
    2. 扩展插件地址:https://github.com/yilezhu/Ocelot.ConfigAuthLimitCache

    总结

    本文主要通过实例讲述如何集成,将配置文件存储到数据库的插件。源码已经开源,今天暂时没有发布Nuget包,明天再发布吧。当然你可以自行扩展代码。实现你自己的业务。我把配置文件存储到数据库的目的就是方便后面做UI管理方便,还有就是可以基于这些路由在数据库中对每个客户端进行单独的限流。最后感谢大家的阅读。

     

    作者:依乐祝

    出处:https://www.cnblogs.com/yilezhu

    联系:1015657114@qq.com .NET Core实战项目交流群:637326624

    本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。如有问题或建议,请多多赐教,非常感谢。
    DotNetCore实战
  • 相关阅读:
    日志格式设计
    域!!!
    Sql Server 2000 中游标的使用示例
    微软下一代操作系统Windows 7仅占25MB空间!
    添加aspnet_isapi.dll的映射时“确定”按钮不可用的解决方案
    巧用Array对象来实现字符串的反转
    [有人帮我说明了原因,明天找人测试一下]紧急求助!!(请您帮看看我的一个在线考试系统的部分代码是否有问题啊?)
    给站长的一点建议
    用SQL SERVER中的的一函数实现表中数据记录随机排序
    使用内嵌资源
  • 原文地址:https://www.cnblogs.com/bigmango/p/10393102.html
Copyright © 2020-2023  润新知