服务网关-微服务小白入门(3)(微服务网关的主要功能)
off999 2025-03-30 19:57 37 浏览 0 评论
基本概念
- Spring Cloud Gateway
Spring Cloud Gateway是基于Spring生态系统之上构建的API网关,包括:Spring 5.x,Spring Boot 2.x和Project Reactor。Spring Cloud Gateway旨在提供一种简单而有效的方法来路由到API,并为它们提供跨领域的关注点,例如:安全性,监视/指标,限流等。
- 什么是服务网关
API Gateway(APIGW / API 网关),顾名思义,是系统对外的唯一入口。API网关封装了系统内部架构,为每个客户端提供定制的API。 近几年来移动应用与企业间互联需求的兴起。从以前单一的Web应用,扩展到多种使用场景,且每种使用场景对后台服务的要求都不尽相同。 这不仅增加了后台服务的响应量,还增加了后台服务的复杂性。随着微服务架构概念的提出,API网关成为了微服务架构的一个标配组件。
- 为什么要使用网关
微服务的应用可能部署在不同机房,不同地区,不同域名下。此时客户端(浏览器/手机/软件工具)想 要请求对应的服务,都需要知道机器的具体 IP 或者域名 URL,当微服务实例众多时,这是非常难以记忆的,对 于客户端来说也太复杂难以维护。此时就有了网关,客户端相关的请求直接发送到网关,由网关根据请求标识 解析判断出具体的微服务地址,再把请求转发到微服务实例。这其中的记忆功能就全部交由网关来操作了。
- 核心概念
路由(Route):路由是网关最基础的部分,路由信息由 ID、目标 URI、一组断言和一组过滤器组成。如果断言 路由为真,则说明请求的 URI 和配置匹配。
断言(Predicate):Java8 中的断言函数。Spring Cloud Gateway 中的断言函数输入类型是 Spring 5.0 框架中 的 ServerWebExchange。Spring Cloud Gateway 中的断言函数允许开发者去定义匹配来自于 Http Request 中的任 何信息,比如请求头和参数等。
过滤器(Filter):一个标准的 Spring Web Filter。Spring Cloud Gateway 中的 Filter 分为两种类型,分别是 Gateway Filter 和 Global Filter。过滤器将会对请求和响应进行处理。
若依的实现
以上是若依的实现,看代码结构来看,基本和单体程序没有什么区别,不过引入了几个包:
通过这个网关,它可以注册到nacos上,本身就是一个服务,
功能
路由
设置路由规则,比如
然后可以由以下方式配置路由规则
限流
熔断降级
跨域配置
黑白名单
全局过滤
Sentinel 限流,分组限流
以下是基本的原理示意:
网关的集群有必要了解一下的:首先可以知道 Gateway 的作用是整个微服务的入口,网关后有许多会员服务,订单服务,支付服务等,一旦有任何请求,想访问到微服务网站,需要经过网关进行转发,到真实的微服务中,如果网关出问题宕机,会导致整个微服务无法实现通讯,因为任何请求需要通过网关在转到服务中,网关是入口,如果网关是宕机的情况下,只要网关出问题就会无法访问。
就例如在企业中有大门,如果大门垮了,别人就进不来了,网关就是整个微服务的入口,如果网关出现问题,整个微服务都无法使用。所以这个地方必须要实现高可用。
在进行访问时按照如下步骤访问,网关不能只有一个,假如现在有两个网关,分别是网关一和网关二,每个网关后配置的服务都是相同的,如果有3个服务,分别是会员服务、订单服务、支付服务,网关转到每个服务中,都是走相同配置。
现在有2个网关,那么要如何得知客户端访问的是哪一个网关,而两个网关背后都是相同配置。答案是网关实现了集群访问可以使用 Njinx 或者 lVS 虚拟 VIP,具体操作要看情况而定,不建议使用虚拟 VIP。
Nginx 和网关是非常相似的,客户端先访问 nginx,nginx 通过配置来实现 nginx控制两个网关,例如走 nginx1时,访问网关一,走 Nginx2时,访问网关二。
但是存在问题当 Nginx 宕机的情况下,网关就访问不了了,所以要清楚 Nginx 也可以多台,可以安排多台Nginx使用相同的配置,中间客户端通过IVS虚拟VIP会随
机绑定到 njinx 中来访问网关。
在大公司中,Nginx 不可能单机版本,因为网关只要一宕机整个微服务就会无法访问,所以网关必须测集群,要实现多个。所以安排多台 Nginx 使用相同的配置,中间客户端通过 IVS 虚拟 VIP 会随机绑定到 njinx 中来访问网关,但是只会在一台机器下面有虚拟 VIP,在宕机的情况下会把虚拟 VIP 转向另一台机器,IVS 是 Linux 独有的技术。
在电商项目中,也是如此。网关必须要做集群,防止出问题。出问题时,可以转换到另一台网关中,能够自动重启。
如果实现多次还是无法进行,机器就会发邮件给运营人员,所以网关可以使用 nginx 或者 IVS 虚拟 VIP 实现集群访问。
总结
基本的功能以及配置的实现,可以参照若依的文档即可,写的比较详细,这里我们需要清楚的是,网关哪些常用的功能,在哪几个位置可以找到,然后我们在哪里可以配置、修改就行。
通过一一系列的文章,我们了解微服务的思想是最重要的,特别是对于编程有影响的地方,重点关注即可。
相关推荐
- 一文搞清 Python 中方法和函数之间的区别
-
在我们使用Python的过程中,经常涉及到方法和函数,那他们有什么不同吗?在本文中,让我们通过示例了解Python中方法和函数之间的区别。Python函数Python函数是一系列以特定顺序...
- Python 数据分析 + 可视化实战:5 分钟出图表,老板看了直点赞
-
还在用Excel做数据分析?效率太低了!同样一份销售数据,同事用Python半小时出报告,图表炫酷还能自动更新;你用Excel捣鼓大半天,稍微改点数据就得重新做图。今天教你用Python...
- Python每日一库之Pendulum(python penup)
-
关于日期处理,Python提供了许多库,例如标准库datetime、第三方库dateutil、Arrow等。在这篇文章中,我想介绍我个人最喜欢的库pendulum,它使用非常方便,它可以满足...
- Python计算两个日期相差天数 M + ACT/360模式,银行计算利息用
-
一般银行在计算计息的时候,都会用到M+ACT/360模式,也就是满1个月按30天计算,不足一个月按实际天数计算。一年算360天。例如:计算20151018到20190817相差的天数,201...
- Python 之 MySql 每日一练 32——查询每门课程的平均成绩
-
一、表名和字段–1.学生表student(s_id,s_name,s_birth,s_sex)–学生编号,学生姓名,出生年月,学生性别–2.课程表course(c_id,c_name,t...
- 用Python制作数据报告:如何自动生成PDF格式的报告?
-
最近在琢磨数据分析工作的自动化,手动做报告真是太费劲啦!试过用Python整了个自动生成PDF报告的小工具,效果还不错。今天就聊聊怎么用Python把数据处理、可视化和PDF生成一条龙搞定。repor...
- Github 1.2k star,一个好用的 Python 库-pyexcel!
-
大家好,今天为大家分享一个好用的Python库-pyexcel。Github地址:https://github.com/pyexcel/pyexcelpyexcel是一个功能强大的Python...
- 使用python写一个简单的到期事件钉钉提醒功能
-
前言:学习python第3天需求:简单的事件提醒功能版本:python3.9、mysql5.71、现在mysql建一个表event_remindCREATETABLE`event_remind`...
- python定时任务最强框架APScheduler详细教程
-
APScheduler定时任务上次测试女神听了我的建议,已经做好了要给项目添加定时任务的决定了。但是之前提供的四种方式中,她不知道具体选择哪一个。为了和女神更近一步,我把我入行近10年收藏的干货免费拿...
- 解放双手,一键运行!Python每日自动生成数据日报
-
对于一个企业来说,高层看意义,中层看结论,基层看落地,数据日报、周报、月报可以监控销售个人在实际执行过程中的销售动态,而数据季度报、年报可以反映一个销售策略是否与实际的业务场景切合。可见数据日报在我们...
- Python模块datetime、calendar、logging、argparse、re用法
-
datetime模块:提供日期和时间相关的功能。importdatetime#获取当前日期和时间current_time=datetime.datetime.now()#格式化日期...
- python入门到脱坑正则表达式—re.search()函数
-
re.search()是Python正则表达式模块re中的核心函数之一,用于在字符串中搜索匹配指定模式的第一个位置。与re.match()不同,它不限制匹配必须从字符串开头开始。基本语法...
- python3从零学习-5.2.1、日历相关模块calendar
-
源代码:Lib/calendar.py这个模块让你可以输出像Unixcal那样的日历,它还提供了其它与日历相关的实用函数。默认情况下,这些日历把星期一当作一周的第一天,星期天为一周的最后一...
- DAY6-step7 Python 示例说明CALENDAR
-
Python中的Calendar模块具有Calendar类,该类允许基于日期,月份和年份来计算各种任务。最重要的是,Python中的TextCalendar和HTMLCalendar类允许您编辑日历...
- Python 数据分析——Pandas 时间序列
-
Pandas提供了表示时间点、时间段和时间间隔等三种与时间有关的类型,以及元素为这些类型的索引对象,并提供了许多时间序列相关的函数。一、时间点、时间段、时间间隔Timestamp对象从Python标准...
你 发表评论:
欢迎- 一周热门
- 最近发表
-
- 一文搞清 Python 中方法和函数之间的区别
- Python 数据分析 + 可视化实战:5 分钟出图表,老板看了直点赞
- Python每日一库之Pendulum(python penup)
- Python计算两个日期相差天数 M + ACT/360模式,银行计算利息用
- Python 之 MySql 每日一练 32——查询每门课程的平均成绩
- 用Python制作数据报告:如何自动生成PDF格式的报告?
- Github 1.2k star,一个好用的 Python 库-pyexcel!
- 使用python写一个简单的到期事件钉钉提醒功能
- python定时任务最强框架APScheduler详细教程
- 解放双手,一键运行!Python每日自动生成数据日报
- 标签列表
-
- python计时 (73)
- python安装路径 (56)
- python类型转换 (93)
- python进度条 (67)
- python吧 (67)
- python字典遍历 (54)
- python的for循环 (65)
- python格式化字符串 (61)
- python静态方法 (57)
- python列表切片 (59)
- python面向对象编程 (60)
- python 代码加密 (65)
- python串口编程 (77)
- python读取文件夹下所有文件 (59)
- java调用python脚本 (56)
- python操作mysql数据库 (66)
- python获取列表的长度 (64)
- python接口 (63)
- python调用函数 (57)
- python多态 (60)
- python匿名函数 (59)
- python打印九九乘法表 (65)
- python赋值 (62)
- python异常 (69)
- python元祖 (57)