当前位置: 首页 > news >正文

Spring Cloud Gateway 网关的基础使用

1. 什么是网关?网关有什么用?

        在微服务架构中,网关就是一个提供统一访问地址的组件,它解决了内部微服务与外部的交互问题。网关主要负责流量的路由和转发,将外部请求引到对应的微服务实例上。同时提供身份认证、授权、限流、监控以及日志记录等功能。

        从上图就能看出网关的作用了,它就是充当客户端与内部微服务之间的桥梁的。前端虽然可以发送ajax,但是它没有健康检测、没有负载均衡,所以需要使用网关来充当一个统一的入口。当前端的请求来到了网关,网关再去分发,因为网关是用 Java 代码来写的,所以可以在网关这里引入Nacos进行健康检测,引入LoadBalancer进行负载均衡。而且它还有超时重试等高级功能。

🍁网关的主要作用

  1. 提供统一的访问入口点:网关作为唯一的网络流量入口和出口,简化了客户端的访问。
  2. 安全控制:网关能够提供安全检查,例如统一登录和授权。
  3. 协议转换:网关可以在不同网络协议之间转换数据,例如处理HTTPS和HTTP之间的转换。
  4. 网络地址的转换:它允许局域网内的多个设备共享一个公共IP地址与外部网络通信,这样做可以提高安全性,节省IP地址,并使内部网络结构对外部不可见。
  5. 数据的过滤和处理:网关可以对流经的数据进行过滤和必要的处理。

2. Spring Cloud Gateway 的基础使用

2.1 Spring Cloud Gateway 的组成

  1. 路由定义访问的目标地址。
  2. 断言:定义一组规则,让匹配到当前路由的请求去调用某个目标。
  3. 过滤器:对请求进行特殊处理。

2.2 Spring Cloud Gateway 最基础的使用

准备工作:

  1. 创建SpringBoot多模块项目
  2. 创建三个模块:网关、订单、用户

假设订单、用户模块在内网中,不能直接访问,需要通过网关路由到对应的服务上面。

准备相关模块中的 controller:

@RestController
@RequestMapping("/order")
public class OrderController {@RequestMapping("/getcount")public int getCount() {return new Random().nextInt(1000);}
}
@RestController
@RequestMapping("/user")
public class UserController {@Autowiredprivate ServletWebServerApplicationContext context; // 获取动态端口@RequestMapping("/getname")public String getName() {return context.getWebServer().getPort() +"--UserService:name=java-"+new Random().nextInt(100);}
}

以上两个某块只需要添加 Spring Web 依赖即可。

使用网关又分为两步:

  1. 添加依赖
  2. 配置规则

1. 添加依赖

<dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-gateway</artifactId>
</dependency>

将其添加到网关模块中,不能添加到父模块中,因为 Spring Cloud Gateway 底层是响应式的 Reactor Web。(会冲突)

2. 配置路由规则

spring:cloud:gateway:routes:- id: userserviceuri: http://localhost:9090  # 路由predicates:  # 断言- Path=/user/**     // 满足断言,就会去走对应的路由- id: orderserviceuri: http://localhost:9091predicates:- Path=/order/**server:port: 10086

在实际业务中,路由 uri 这里肯定不能直接写死,但是此处主要演示最基础的使用。

        完成以上两步之后,运行订单服务、用户服务,网关,使用10086端口去访问两个内网中的服务,都能访问的到,这样就实现了统一入口!

2.3 单服务中的多路径配置

        在上述示例中,每个服务只有一个controller,所以在配置网关路由规则的时候,直接写就行了,假如说,单个服务中有多个controller呢?路由规则该如何去写?

在user-service模块中创建日志controller:

@RestController
@RequestMapping("/userlog")
public class UserLogController {@RequestMapping("/getlog")public String getLog() {return "UserLogService:log=java-"+new Random().nextInt(1000);}
}

多路径配置:

spring:cloud:gateway:routes:- id: userserviceuri: http://localhost:9090  # 路由predicates:  # 断言- Path=/user/**,/userlog/getlog  # 单服务多路径配置- id: orderserviceuri: http://localhost:9091predicates:- Path=/order/**server:port: 10086

        如果需要在单服务中完成多路径配置,那么这个时候只需要在Path后面写多个匹配规则,用英文的逗号隔开即可。不能在predicates下面在搞一个Path,因为同一个predicates下面不能出现相同类型的断言。

2.4 更多的断言类型

1.根据时间匹配 (3种类型)

  • After:请求在指定时间之后才匹配。
  • Before:请求在指定时间之前才匹配。
  • Between:请求在指定时间中间才匹配。

2. Cookie:配置请求中的 Cookie 值。

3. Header:配置请求中的 Header 值。

4. Host:配置请求头中的 Host 值。

5. Method:匹配请求头中 Method 的值。

6. Path:匹配请求路径。

7. Query:匹配请求参数。

8. RemoteAddr:匹配请求的 IP 地址,支持 IPV4 和 IPV6.

9. Weight:根据权重来分发请求,权重根据 group 来计算。

10. XForwardedRemoteAddr:根据 X-Forwarded-For 匹配。

参考官方文档:https://docs.spring.io/spring-cloud-gateway/docs/current/reference/html/#gateway-request-predicates-factories

【示例】演示 Header

spring:cloud:gateway:routes:- id: userserviceuri: http://localhost:9090  # 路由predicates:  # 断言- Path=/user/**,/userlog/getlog  # 单服务多路径配置- Header=X-Header-Flag, \d+  server:port: 10086

使用 postman 构造 header:

① 正常访问

② 异常访问

 

       上述例子中,”X-Header-Flag“ 表示 Header 中的 key,”\d+“ 是一个正则表达式,表示 key 的值,此处表示匹配 1 个或多个数字,才能访问的到。

其他正则表达式:

  1. \w+:匹配一个或多个字母、数字、下划线字符。
  2. \s+:匹配一个或多个空白字符(空格、制表符、换行符)。
  3. .*:匹配任意字符0次或多次。
  4. .+:匹配除了换行符之外的任意字符一次或多次。
  5. [abc]:匹配字符集中的任意一个字符,例如 [abc] 可以匹配 a、b、或 c。
  6. [^abc]:匹配除了字符集中的任意字符之外的任意字符。
  7. ^:匹配字符串的开始位置。
  8. &:匹配字符串的结束位置。
  9. |:用于匹配多个模式中的任意一个。
  10. ():用于分组,,可以将一组字符作为一个整体进行匹配。

http://www.lryc.cn/news/256541.html

相关文章:

  • 小米手机锁屏时间设置为永不休眠_手机不息屏_保持亮屏
  • lightdb plorasql集合类型新增可变数组
  • 算法--最短路
  • Linux 定时任务备份MySQL数据库
  • 查询服务器CPU、内存、磁盘、网络IO、队列、数据库占用空间等等信息
  • 外观模式 rust和java的实现
  • uniapp-hubildx配置
  • Nginx基础篇:Nginx搭建、Nginx反向代理、文件服务器部署配置。
  • 什么是TDR(威胁检测与响应)
  • 30、pytest入门内容回顾
  • 2023年 - 我的程序员之旅和成长故事
  • JMH性能测试
  • 超完整的mysql安装配置方法(包含idea和navicat连接mysql,并实现建表)
  • 通过仿真理解完整的阵列信号噪声模型
  • 问题:数组对象去重
  • 前端:让一个div悬浮在另一个div之上
  • 千锋 Vue 详细笔记整理
  • uniapp实战 —— 骨架屏
  • 【数据仓库-10】-- 数据仓库、数据湖和湖仓一体对比
  • 单臂路由与三层交换机
  • 免费的数据采集软件,最新免费的几款数据采集软件【2024】
  • nodejs微信小程序+python+PHP北京地铁票务APP-计算机毕业设计推荐 -安卓
  • zabbix 进阶
  • 【性能测试】Jmeter 配置元件(一):计数器
  • 使用Dockerfile Maven Plugin 将Docker镜像Push到AWS ECR (Elastic Container Registry)
  • ubuntu 20.04.6 server 服务器 下载与安装(配置静态IP)
  • [Linux] Apache的配置与运用
  • PHP基础 - 注释变量
  • 【图论笔记】克鲁斯卡尔算法(Kruskal)求最小生成树
  • oops-framework框架 之 多语言设置文本、精灵和骨骼动画