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

 本来这篇文章在昨天晚上就能发布的,悲剧的是写了两三千字的文章居然没保存,结果我懵逼了。今天重新来写这篇文章。今天我们就一起来探讨下如何重写Ocelot配置文件的存储方式以及获取方式。

作者:依乐祝
原文地址:

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

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管理方便,还有就是可以基于这些路由在数据库中对每个客户端进行单独的限流。最后感谢大家的阅读。

Ocelot简易教程目录

  1. Ocelot简易教程(一)之Ocelot是什么
  2. Ocelot简易教程(二)之快速开始1
  3. Ocelot简易教程(二)之快速开始2
  4. Ocelot简易教程(三)之主要特性及路由详解
  5. Ocelot简易教程(四)之请求聚合以及服务发现
  6. Ocelot简易教程(五)之集成IdentityServer认证以及授权
  7. Ocelot简易教程(六)之重写配置文件存储方式并优化响应数据
如果您认为这篇文章还不错或者有所收获,您可以点击右下角的【推荐】按钮精神支持,因为这种支持是我继续写作,分享的最大动力!
作者:
yilezhu(依乐祝)
声明:原创博客请在转载时保留原文链接或者在文章开头加上本人博客地址,如发现错误,欢迎批评指正。凡是转载于本人的文章,不能设置打赏功能,如有特殊需求请与本人联系!https://www.cnblogs.com/yilezhu/p/9839863.html
50000+
5万行代码练就真实本领
17年
创办于2008年老牌培训机构
1000+
合作企业
98%
就业率

联系我们

电话咨询

0532-85025005

扫码添加微信