.net core 3.1 使用 Ocelot 付源码
2021/11/9 11:10:28
本文主要是介绍.net core 3.1 使用 Ocelot 付源码,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
我又来做学习笔记了....
本文是对初步认识网关做一个笔记,刚刚学习,若有不足之处还请指正。
网关的理解
API网关是微服务架构中的唯一入口,它提供一个单独且统一的API入口用于访问内部一个或多个API。它可以具有身份验证,监控,负载均衡,缓存,请求分片与管理,静态响应处理等。API网关方式的核心要点是,所有的客户端和消费端都通过统一的网关接入微服务,在网关层处理所有的非业务功能。通常,网关也是提供REST/HTTP的访问API。服务端通过API-GW注册和管理服务。
在做功能之前我们都需要知道我们要做什么(也就是需求是什么?,有什么作用?)。
本文要学习的点是 API网关是微服务架构中的唯一入口,它提供一个单独且统一的API入口用于访问内部一个或多个API
从这里可以了解需求为,微服务存在N个APiService : ApiService1,ApiService2.....345,正确情况下请求ApiService1为ApiService1端口/api/[controller]/[action] ,请求ApiService2为ApiService2端口/api/[controller]/[action] ,而网关就是把这些请求入口统一访问网关,网关再根据路由转向下游Api
如:
网关 http://localhost:9000
ApiService1 http://localhost:9001(存在接口 Api/Product/Get)正常请求就是 http://localhost:9001/Api/Product/Get
ApiService2 http://localhost:9002 (存在接口 Api/User/Get) 正常请求就是 http://localhost:9002/Api/User/Get
而网关则是把他们的请求统一起来 使用 http://localhost:9000去请求对应路由 如:
请求http://localhost:9001/Api/Product/Get使用 http://localhost:9000/Api/Product/Get
请求http://localhost:9002/Api/User/Get使用 http://localhost:9000/Api/User/Get
实现
Ocelot介绍
Ocelot是用.net Core实现的一款开源的网关,Ocelot其实就是一组按照顺序排列的.net core中间件。它接受到请求之后用request builder构建一个HttpRequestMessage对象并发送到下游服务,当下游请求返回到Ocelot管道时再由一个中间件将HttpRequestMessage映射到HttpResponse上返回客户端
代码实现看源码哈,我这里就不多叨叨了
参考文章
.net core 3.1 使用 Ocelot搭建api网关
Git源码地址 https://gitee.com/nwd_git/Ocelot
这篇关于.net core 3.1 使用 Ocelot 付源码的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2022-03-01沐雪多租宝商城源码从.NetCore3.1升级到.Net6的步骤
- 2024-05-08首个适配Visual Studio平台的国产智能编程助手CodeGeeX正式上线!C#程序员必备效率神器!
- 2024-03-30C#设计模式之十六迭代器模式(Iterator Pattern)【行为型】
- 2024-03-29c# datetime tryparse
- 2024-02-21list find index c#
- 2024-01-24convert toint32 c#
- 2024-01-24Advanced .Net Debugging 1:你必须知道的调试工具
- 2024-01-24.NET集成IdGenerator生成分布式全局唯一ID
- 2024-01-23用CI/CD工具Vela部署Elasticsearch + C# 如何使用
- 2024-01-23.NET开源的简单、快速、强大的前后端分离后台权限管理系统