6. 【.NET 8 实战--孢子记账--从单体到微服务--转向微服务】--微服务基础工具与技术--Ocelot 网关--概念与简单入门

网关是一种位于客户端和后端服务之间的服务,充当所有客户端请求的单一入口。它的主要职责是接收所有的API调用,汇总各类请求,将其路由到适当的后端服务,并将响应返回给客户端。网关不仅仅是一个简单的反向代理,它还能够处理认证、授权、负载均衡、缓存、请求和响应的转换等多种功能。
在微服务架构中,系统通常由多个独立的服务组成,这些服务各自负责不同的业务功能。当客户端需要与这些服务进行交互时,直接调用各个服务会带来一系列的问题。首先,客户端需要了解每个服务的地址和接口,当服务数量众多时,这种复杂性会迅速增加。其次,不同的服务可能使用不同的协议和数据格式,客户端需要处理这些差异。最后,为了实现认证、授权、限流、日志记录和监控等功能,每个服务都需要重复实现这些通用功能,导致代码重复和维护困难。
网关通过提供一个统一的接口,简化了客户端与后端服务的交互。客户端只需要与网关交互,而不需要关心后端服务的具体实现和位置。网关可以进行负载均衡,将请求分发到多台后端服务器上,以提高系统的可用性和性能。它还可以缓存某些请求的响应,减少后端服务的负载。通过集中处理认证和授权,网关可以确保安全性和一致性,而不需要在每个服务中重复实现这些功能。
此外,网关能够对请求和响应进行转换和聚合。例如客户端可能需要从多个服务中获取数据,网关可以在后端服务之间协调,汇总结果并返回给客户端。这不仅简化了客户端的开发,还可以减少网络延迟,提高响应速度。

一、Ocelot概述

Ocelot是基于.NET Core的开源网关,旨在为微服务架构和服务导向架构提供统一的入口。作为网关,Ocelot通过提供一系列强大而灵活的功能,帮助开发者轻松管理和路由客户端请求。
Ocelot的核心功能之一是路由。通过定义路由规则,Ocelot能够将客户端的请求转发至适当的后端服务。每个路由规则包括一个上游路径(客户端请求的路径)和一个下游路径(后端服务的路径)。这种映射机制使得Ocelot可以灵活地处理不同的请求,确保客户端与后端服务之间的通信顺畅。此外,Ocelot支持路径参数和查询参数的传递,使路由规则更加灵活和强大。
为了提高系统的可用性和性能,Ocelot提供了多种负载均衡策略,包括轮询(Round Robin)和最少连接(Least Connection)。轮询策略将请求依次分发到每个可用的后端服务实例,从而均衡负载;最少连接策略则将请求分发到当前连接数最少的服务实例,以确保每个实例的负载均衡。通过配置负载均衡策略,Ocelot能够有效地分配请求,避免单个服务实例过载。
在微服务架构中,服务实例的数量和地址可能是动态变化的。为了实现动态路由,Ocelot集成了服务发现功能,可以与Consul和Eureka等服务注册中心进行集成。通过服务发现,Ocelot可以自动获取可用的服务实例列表,并将请求路由到健康的实例上。这不仅简化了服务管理,还提高了系统的可靠性和可扩展性。
请求聚合是Ocelot的一个重要特性,特别适用于需要从多个服务中获取数据的场景。Ocelot可以将多个下游服务的响应合并为一个响应返回给客户端,从而减少客户端的调用次数,提高响应速度。通过配置聚合路由,开发者可以定义哪些服务的响应需要聚合,以及如何合并这些响应。这种功能在构建复杂的API时非常有用,能够显著简化客户端的逻辑。
在安全性方面,Ocelot提供了多种认证和授权机制,以确保请求的合法性和安全性。常见的认证机制包括JWT(JSON Web Token)认证和与IdentityServer的集成。通过配置认证策略,Ocelot可以在处理请求之前验证令牌的有效性,并根据权限控制访问。此外,Ocelot还支持IP白名单和黑名单、SSL/TLS终止等安全功能,进一步增强了系统的安全性。
为了帮助开发者跟踪请求的处理过程,监控系统的健康状况,Ocelot提供了丰富的日志和监控功能。通过集成日志框架(如Serilog),Ocelot可以记录请求的详细信息,包括请求路径、响应时间、状态码等。开发人员可以根据这些日志进行问题排查和性能分析。Ocelot还支持与Prometheus等监控工具的集成,实时监控系统的各项指标,确保系统的稳定运行。
Ocelot的配置文件使用JSON格式,支持多种配置选项。开发者可以根据需求灵活配置路由、负载均衡、服务发现、认证、日志等功能。Ocelot还支持热更新配置,即在不重启服务的情况下动态更新配置文件。这使得Ocelot在应对变化和调整时更加灵活和高效。
Ocelot的设计高度模块化,支持通过中间件扩展功能。开发者可以根据具体需求编写自定义中间件,插入到请求处理管道中,增加或修改Ocelot的功能。这种扩展性使得Ocelot能够适应各种复杂的业务场景,满足不同应用的需求。

二、 Ocelot的安装与配置

2.1 安装

安装Ocelot非常简单,首先要确保已安装.NET Core SDK,接着创建一个新的ASP.NET Core项目。在命令行中运行以下命令:

dotnet new webapi -n OcelotApiGatewayDemo

进入项目目录:

cd OcelotApiGateway

使用NuGet包管理器安装Ocelot。在命令行中运行以下命令:

dotnet add package Ocelot

安装完成后,打开Program.cs文件,在Main方法中添加Ocelot服务:

builder.Services.AddOcelot();

Main方法中添加Ocelot中间件:

app.UseOcelot().Wait();

最后,在项目根目录创建ocelot.json空的配置文件,它用来定义路由和其他配置。到此,Ocelot已成功安装并配置完毕。

2.2 配置

在这一小节,我们以服务转发为例简单讲解一下Ocelot的配置。打开上一小节创建的ocelot.json空配置文件,在其中输入如下内容:

{"Routes": [{"DownstreamPathTemplate": "/api/users","DownstreamScheme": "http","DownstreamHostAndPorts": [{"Host": "localhost","Port": 5001}],"UpstreamPathTemplate": "/users","UpstreamHttpMethod": [ "GET" ]}],"GlobalConfiguration": {"BaseUrl": "https://localhost:5000"}
}

在这个配置文件中Routes定义了一个路由规则,其中DownstreamPathTemplate指定了下游服务的路径模板,DownstreamScheme指定了下游服务使用的协议(http或https),DownstreamHostAndPorts指定了下游服务的主机和端口。而UpstreamPathTemplate则指定了上游路径模板,即客户端请求的路径,最后UpstreamHttpMethod配置了允许的HTTP方法(如GET、POST等)。GlobalConfiguration它是一个全局全局配置,其中的BaseUrl指定API网关的基础URL。
完成ocelot.json配置后,打开Program.cs文件,在Main方法中添加对ocelot.json的支持:

// 添加Ocelot配置文件
builder.Configuration.AddJsonFile("ocelot.json", optional: false, reloadOnChange: true);

这样,Ocelot将读取并使用ocelot.json文件中的配置。启动API网关应用,客户端请求https://localhost:5000/users时,Ocelot会将请求转发到http://localhost:5001/api/users

三、总结

本篇文章主要介绍了网关的概念,以及在.NET开发中常用的Ocelot 网关,从下一篇文章开始,我们将一起学习Ocelot 网关的各个功能。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/896128.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

网页制作06-html,css,javascript初认识のhtml如何建立超链接

超链接有外部链接、电子邮件链接、锚点链接、空链接、脚本链接 一、内部链接 与自身网站页面有关的链接被称为内部链接 1、创建内部链接 1&#xff09;语法&#xff1a; <a href"链接地址"> …… </a> 2&#xff09;举例应用&#xff1a; 3&#xf…

MySQL后端返回给前端的时间变了(时区问题)

问题&#xff1a;MySQL里的时间例如为2025-01-10 21:19:30&#xff0c;但是返回到前端就变成了2025-01-10 13:19:30&#xff0c;会出现小时不一样或日期变成隔日的问题 一般来说设计字段时会使用datetime字段类型&#xff0c;这是一种用于时间的字段类型&#xff0c;而这个类型…

【算法与数据结构】单调队列

目录 单调队列 使用单调队列维护滑动窗口 具体过程&#xff1a; 代码实现&#xff1a; 复杂度分析&#xff1a; 使用单调队列优化动态规划 例题 单调队列 单调队列(deque)是一种特殊的队列&#xff0c;队列中的元素始终按严格递增或者递减排列。这样就可以保证队头元素…

AutoGen 技术博客系列 九:从 v0.2 到 v0.4 的迁移指南

本系列博文在掘金同步发布, 更多优质文章&#xff0c;请关注本人掘金账号&#xff1a; 人肉推土机的掘金账号 AutoGen系列一&#xff1a;基础介绍与入门教程 AutoGen系列二&#xff1a;深入自定义智能体 AutoGen系列三&#xff1a;内置智能体的应用与实战 AutoGen系列四&am…

深度学习每周学习总结Y1(Yolov5 调用官方权重进行检测 )

&#x1f368; 本文为&#x1f517;365天深度学习训练营 中的学习记录博客Y1中的内容 &#x1f356; 原作者&#xff1a;K同学啊 | 接辅导、项目定制 ** 注意该训练营出现故意不退押金&#xff0c;恶意揣测偷懒用假的结果冒充真实打卡记录&#xff0c;在提出能够拿到视频录像…

为AI聊天工具添加一个知识系统 之117 详细设计之58 思维导图及观察者效应 之2 概念全景图

&#xff08;说明&#xff1a;本文和上一篇问题基本相同&#xff0c;但换了一个模型 deepseek-r1&#xff09; Q1227、在提出项目“为使用AI聊天工具的聊天者加挂一个专属的知识系统”后&#xff0c;我们已经进行了了大量的讨论-持续了近三个月了。这些讨论整体淋漓尽致体现了…

2012年IMO几何预选题第6题

设有非等腰的 △ A B C \triangle ABC △ABC, O O O 和 I I I 分别为外心和内心. 在边 A C AC AC, A B AB AB 上分别存在两点 E E E 和 F F F, 使得 C D C E A B CDCEAB CDCEAB, B F B D A C BFBDAC BFBDAC. 设 ( B D F ) (BDF) (BDF) 和 ( C D E ) (CDE) (CDE)…

为Eclipse IDE安装插件IBM编程助手watsonx Code Assistant

从Eclipse IDE 安装 从Eclipse IDE 安装插件&#xff1a; _1、在Eclipse IDE 中&#xff0c;单击帮助菜单&#xff0c;然后选择EclipseMarketplace。 _2、根据您计划进行的工作类型选择安装方式&#xff1a; 有关代码建议、代码解释、代码文档和单元测试的集成生成式人工智能&a…

Linux基本指令(三)+ 权限

文章目录 基本指令grep打包和压缩zip/unzipLinux和windows压缩包互传tar&#xff08;重要&#xff09;Linux和Linux压缩包互传 bcuname -r常用的热键关机外壳程序 知识点打包和压缩 Linux中的权限用户权限 基本指令 grep 1. grep可以过滤文本行 2. 把包含9的文本行过滤出来了 …

【部署优化篇十四】【十万字全景拆解:GitHub Actions自动化流水线设计圣经(DeepSeek工业级实践大公开)】

一、从手工作坊到智能工厂:CI/CD的革命之路 想象一下,你所在的公司每天要手工组装1000台手机,每个环节都靠老师傅肉眼检查——这就是没有CI/CD的软件开发现状。GitHub Actions的出现,就像给软件交付装上了特斯拉的超级工厂流水线。 DeepSeek的CI/CD演进史就是一部血泪史:…

“死”循环(查漏补缺)

以下代码会死循环&#xff1a; #include<iostream> using namespace std; int n,res; int main(){cin>>n;for(int i1;i<n;i){int xi;while(i){int ti%10;i/10;if(t2||t0||t1||t9){resx;break;}}}cout<<res<<endl;return 0; } 你的代码中存在一个逻…

力扣LeetCode: 2506 统计相似字符串对的数目

题目&#xff1a; 给你一个下标从 0 开始的字符串数组 words 。 如果两个字符串由相同的字符组成&#xff0c;则认为这两个字符串 相似 。 例如&#xff0c;"abca" 和 "cba" 相似&#xff0c;因为它们都由字符 a、b、c 组成。然而&#xff0c;"aba…

关于Java 反射的简单易懂的介绍

目录 #0.总览 #1. 类的反射 ①介绍 ②获取 ③作用 获取构造函数&#xff1a; 创建实例&#xff1a; 字段操作&#xff1a; 方法操作&#xff1a; 获取修饰符&#xff1a; #2.总结 #0.总览 反射&#xff0c;官方是这样介绍它的&#xff1a; Reflection is a …

【精调】LLaMA-Factory 快速开始1: Meta-Llama-3.1-8B-Instruct

llamafactory-cli train examples/train_lora/llama3_lora_sft.yaml llamafactory-cli chat examples/inference/llama3_lora_sft.yaml llamafactory-cli export examples/merge_lora/llama3_lora_sft.yaml模型下载 git clone https://www.modelscope.cn/LLM-Research/Meta-Lla…

【07】区块链性能

7-1 基础性能优化 7-1-1 区块链性能瓶颈 总述 区块链性能指标 区块链的性能指标主要包括&#xff1a; 吞吐量&#xff1a;在固定时间内处理的交易数量 延时&#xff1a;对交易的响应和处理时间 主流区块链与中心化平台TPS对比 区块链与传统计算的对比 区块链可信且中立…

安全面试2

文章目录 简单描述一下什么是水平越权&#xff0c;什么是垂直越权&#xff0c;我要发现这两类漏洞&#xff0c;那我代码审计要注意什么地方水平越权&#xff1a;垂直越权&#xff1a;水平越权漏洞的审计重点垂直越权漏洞的审计重点 解释一下ssrf漏洞原理攻击场景修复方法 横向移…

【Linux 专栏】echo命令实验

风123456789&#xff5e;-CSDN博客 最近文章阅读排行榜 【爬虫基础】第一部分 网络通讯 P1/3-CSDN博客 【爬虫基础】第一部分 网络通讯-Socket套接字 P2/3-CSDN博客 【Linux专栏】find命令同步 实验-CSDN博客 【Linux运维】非root用户的单向免密登录_linux 单向免密-CSDN博客…

RTSP协议全解析

RTSP&#xff08;Real Time Streaming Protocol&#xff09;协议全解析 一、协议概述 定位&#xff1a;应用层协议&#xff0c;用于控制流媒体服务器&#xff08;播放、暂停、录制&#xff09;&#xff0c;媒体传输由 RTP/RTCP 实现。 特点&#xff1a; 基于文本&#xff08;…

第15届 蓝桥杯 C++编程青少组中/高级选拔赛 202401 真题答案及解析

第 1 题 【 单选题 】 表达式117 % 16 的结果是( )。 A:0 B:5 C:7 D:10 解析: % 是取模运算符,用于计算两个数相除后的余数。 计算 117 / 16,结果是 7,余数是 5。因此,117 % 16 = 5。答案: B 第 2 题 【 单选题 】 下列选项中,字符数组定义正确的是( …

qt5实现表盘的旋转效果,通过提升QLabel类

因为工作需要&#xff0c;需要实现温度的表盘展示效果 实现思路&#xff1a; 通过提示声QLabel控价类&#xff0c;实现报盘的旋转和展示效果 1. 编写一个QLabel的类MyQLabel,实现两个方法 1. void paintEvent(QPaintEvent *event); //重绘函数 2. void valueChanged(int va…