spring cloud之网关

news2024/11/19 7:27:35

Gateway网关(*)

什么是网关

# 1.说明
- 网关统一服务入口,可方便实现对平台众多服务接口进行管控。
- 网关 = 路由转发 + 过滤器
	路由转发:接收一切外界请求,转发到后端的微服务上去
	过滤器:在服务网关中可以完成一系列的横切功能,例如权限校验、限流及监控等等,这些都可以用过滤器来完成

# 网关作用
- 1.网关统一所有微服务入口
- 2.网关可以实现请求路由转发,以及负载均衡
- 3.访问服务的身份认证、防报文重发、防数据篡改、功能调用的业务鉴权、响应数据的脱敏、流量与并发控制,甚至基于API调用的计量或计费等
- 4.网关可以解决微服务中通用代码的冗余问题(如权限控制,流程监控,限流等)
  • 网关组件在微服务中架构
    在这里插入图片描述

服务网关组件

zuul
# 官网:https://github.com/Netflix/zuul/wiki
- zuul是从设备到网站到Netflix流媒体应用程序后端的所有请求的前门。作为一个边缘服务应用程序,zuul被构建为支持动态路由、监视、弹性和安全性

# zuul版本说明
- 目前zuul组件已经从1.0更新到2.0,但是springcloud官方不再推荐使用zuul2.0,依然支持zuul2.0

# springcloud 官方集成zuul文档
- https://cloud.spring.io/spring-cloud-netflix/2.2.x/reference/html/#netflix-zuul-starter
gateway(spring)
# 官网:http://spring.io/projects/spring-cloud-gateway
- 这个项目提供了一个在springmvc之上构建API网关的库。spring-cloud-gateway提供一种简单而有效的方法来路由到api,并为api提供横切关注点,比如:安全性、监控、度量和弹性

# 特性
- 基于springboot2.x 和 spring webFlux 和 Reactor 构建响应式异步非阻塞IO模型
- 动态路由
- 请求过滤
1.开发网关动态路由
  • 添加依赖
<dependencies>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
    </dependency>
    <!-- 健康检查 -->
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-actuator</artifactId>
    </dependency>

    <!-- consul 注册中心 -->
    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-starter-consul-discovery</artifactId>
    </dependency>
    <!-- gateway 网关 -->
    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-starter-gateway</artifactId>
    </dependency>
</dependencies>
  • 基于配置文件方式配置gateway(推荐)
server:
  port: 8999

spring:
  application:
    name: GATEWAY
  cloud:
    consul:
      host: localhost
      port: 8500
    gateway:
      routes:
        # 路由唯一标识
        - id: user_router
          # 指定路由服务的地址
          uri: http://localhost:8888
          # 断言,用来配置路由规则
          predicates:
          	# 路径匹配,会路由转发到 http://localhost:8888/user/**
            - Path=/user/**
        - id: order_router
          uri: http://localhost:9999
          predicates:
            - Path=/order/**
  • 基于java代码方式配置gateway
/**
 * 基于java代码实现路由配置
 *
 * @author coolw
 * @Date 2022/1/17 23:51
 * @since 1.0
 */
@Configuration
public class GatewayConfig {

    @Bean
    public RouteLocator customRouteLocator(RouteLocatorBuilder builder) {
        return builder.routes()
            	// 用户路由规则
                .route("user_router", r -> r.path("/user/**").uri("http://localhost:8888"))
            	// 订单路由规则
                .route("order_router", r -> r.path("/order/**").uri("http://localhost:9999"))
                .build();
    }
}
  • gateway测试
- 当访问 http://localhost:8999/user,会路由转发到 http://localhost:8888/user
- 当访问 http://localhost:8999/order,会路由转发到 http://localhost:9999/order

路由转发路径直接写死为ip:port,不利于维护,且无法实现负载均衡,不推荐使用。

2.网关路由转发实现负载均衡,集成Ribbon(负载均衡客户端组件)
  • 配置文件,路由服务地址固定写法 lb://服务名,lb:LoadBalanced 负载均衡
spring:
  application:
    name: GATEWAY
  cloud:
    consul:
      host: localhost
      port: 8500
    gateway:
      routes:
        # 商品路由
        - id: product_route
          # 实现负载均衡。lb:LoadBalanced 负载均衡,PRODUCT:服务名
          uri: lb://PRODUCT
          predicates:
            - Path=/product/**
3.网关-断言 Route Predicate Factories
# 断言:当请求到达网关时,网关前置处理,满足断言则放行请求,不满足则返回失败

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

# 网关断言种类
predicates:	
	# 满足指定的路径规则,允许访问
	- Path=/user/**
	# 在指定的时间后,允许访问
	- After=2022-01-18T22:55:41.815+08:00[Asia/Shanghai]
	# 在指定的时间前,允许访问
	- Before=2022-01-18T22:55:41.815+08:00[Asia/Shanghai]
	# 在指定时间范围内,允许访问
	- Between=2022-01-18T22:55:41.815+08:00[Asia/Shanghai], 2022-01-18T23:55:41.815+08:00[Asia/Shanghai]
	# 指定Cookie的key为name,value为zhangsan,允许访问
	- Cookie=name, zhangsan
	......其他断言种类见官方文档
  • 断言接口类RoutePredicateFactory所实现的断言子类
4.网关-过滤器 GatewayFilter Factories
# 过滤器:当请求满足断言的条件后,会向后端服务进行路由转发,在向后端服务转发之前可以设置经过一些过滤器

# 官方文档:https://docs.spring.io/spring-cloud-gateway/docs/2.2.7.RELEASE/reference/html/#gatewayfilter-factories

# 过滤器种类
filters:
	# 用来给路由对象的转发请求加入指定请求头信息(key,value)
	- AddRequestHeader=X-Request-color, blue
	# 用来给路由对象的转发请求加入指定请求参数(key,value)
	- AddRequestParameter=color, blue
	# 用来给路由对象的转发请求的响应加入指定请求头信息
	- AddResponseHeader=X-Response-Red, Blue
	# 在路由转发到后端服务时,添加前缀(例如,前端请求地址/user/list,指定PrefixPath为/mypath,则路由转发到后端地址为/mypath/user/list)
	- PrefixPath=/mypath
	# 在路由转发到后端服务时,去掉指定n个的前缀(例如,前端请求地址/api/user/list,指定StripPrefix为1,则路由转发到后端地址为/user/list)
	- StripPrefix=1
	......其他过滤器种类见官方文档
  • 过滤器接口GatewayFilterFactory所实现的子类
    在这里插入图片描述
5.自定义全局过滤器
# 官方文档:https://docs.spring.io/spring-cloud-gateway/docs/2.2.7.RELEASE/reference/html/#global-filters
  • 代码示例
/**
 * 自定义全局过滤器
 *
 * @author coolw
 * @Date 2022/1/18 23:49
 * @since 1.0
 */
@Component
@Slf4j
public class CustomerGlobalFilter implements GlobalFilter, Ordered {
    @Override
    public Mono<Void> filter(ServerWebExchange exchange, GatewayFilterChain chain) {
        ServerHttpRequest request = exchange.getRequest();
        ServerHttpResponse response = exchange.getResponse();

        // TODO 执行过滤器前的业务逻辑

        Mono<Void> filter = chain.filter(exchange);

        // TODO 执行过滤器后的业务逻辑
        
        return filter;
    }

    /**
     * 如果有多个全局过滤器类,可以指定过滤器执行顺序,越小则越先执行,默认为0
     * -1:最先执行。如果有多个全局过滤器的order值相同,则按自然顺序执行
     */
    @Override
    public int getOrder() {
        return -1;
    }
}
6.查看网关路由规则列表
  • 网关服务的配置文件,暴露健康检查的端点
management:
  endpoints:
    web:
      exposure:
        # 暴露所有端点。也可以指定需要暴露的端点列表
        include: "*"
  • 访问网关地址 http://localhost:8999/actuator/gateway/routes
    在这里插入图片描述

  • 断言和过滤器配置示例

server:
  port: 8999

spring:
  application:
    name: GATEWAY
  cloud:
    consul:
      host: localhost
      port: 8500
    gateway:
      routes:
        # 用户路由唯一标识
        - id: user_route
          # 指定路由服务的地址
          uri: http://localhost:8888
          # 断言,用来配置路由规则
          predicates:
            - Path=/user/**
        # 订单路由
        - id: order_route
          uri: http://localhost:9999
          predicates:
            - Path=/order/**
        # 商品路由
        - id: product_route
          # 实现负载均衡。lb:LoadBalanced 负载均衡,PRODUCT:服务名
          uri: lb://PRODUCT
          predicates:
            # 满足路径规则,放行
            - Path=/api/gateway/product/**
            # 在指定的时间后,放行
            - After=2022-01-19T00:12:10.815+08:00[Asia/Shanghai]
          filters:
            # 去掉指定个数的前缀,例如/api/gateway/product/**  -> 转发到后端服务的路径会去掉/api/gateway -> /product/**
            - StripPrefix=2
            # 添加前缀,例如/test/** -> 转发到后端服务的路径会添加/product -> /product/test/**
            - PrefixPath=/product

management:
  endpoints:
    web:
      exposure:
        # 暴露所有端点。也可以指定需要暴露的端点列表
        include: "*"

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

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

相关文章

学Diffusion前需要储备的一些知识点

自学Diffusion是非常困难的&#xff0c;尤其是到了VAE和VI这里基本找不到比较好的中文资料&#xff0c;甚至是涉及到一些重参数化&#xff0c;高斯混合之类的问题摸不着来龙去脉。在本文中&#xff0c;基本不会涉及公式&#xff0c;只有intuition和理解&#xff0c;如果要看公式…

Pytorch CUDA CPP简易教程,在Windows上操作

文章目录 前言一、使用的工具二、学习资源分享三、libtorch环境配置1.配置CUDA、nvcc、cudnn2.下载libtorch3.CLion配置libtorch4.CMake Application指定Environment variables5.测试libtorch 四、PyTorch CUDA CPP项目流程1.使用CLion结合torch extension编写可以调用cuda的C代…

推介会如何做好媒体宣传

传媒如春雨&#xff0c;润物细无声&#xff0c;大家好&#xff0c;我是51媒体网胡老师。 推介会是一种专为企业、社会组织和团体、政府等提供的展示自身特点、产品和政策的活动形式&#xff0c;旨在促进交流活动&#xff0c;形成合作&#xff0c;从而带来共同利益。推介会的本…

硬盘分区后数据还能恢复吗?答案揭晓!

“前两天刚给我的电脑硬盘分了区&#xff0c;但今天在查找数据时却发现某些数据丢失了。硬盘分区导致的数据丢失还有机会找回吗&#xff1f;怎么操作呢&#xff1f;请帮帮我&#xff01;” 在使用电脑时&#xff0c;可能由于电脑需要重装系统&#xff0c;或者出现系统崩溃的情况…

天气越来越寒冷,一定要注意保暖

你们那里下雪了吗&#xff1f;听说西安已经下了今年的第一场雪&#xff0c;我们这里虽然隔了几百公里&#xff0c;但是只下雨没有下雪&#xff0c;不过气温是特别的冷&#xff0c;尤其是对我们这些上班族和上学的人而言&#xff0c;不管多冷&#xff0c;不管刮风下雨&#xff0…

InputStream和OutputStream

文章目录 &#x1f4a1;FileInputStream 构造方法&#x1f4a1;InputStream 常用方法&#x1f4a1;OutputStream 概述&#x1f4a1;OutputStream 常用方法&#x1f4a1;PrintWriter&#x1f4a1;小程序练习 使用字节流进行读/写操作时&#xff0c;是以字节为单位的&#xff1b;…

Python如何使用Matplotlib模块的pie()函数绘制饼形图?

Python如何使用Matplotlib模块的pie函数绘制饼形图&#xff1f; 1 模块安装2 实现思路3 pie()函数说明4 实现过程4.1 导入包4.2 定义一个类4.3 读取数据并处理4.4 定义饼图绘制方法 5 完整源码 1 模块安装 先安装matplotlib&#xff1a; pip install matplotlib安装numpy模块…

Pandas教程(非常详细)(第六部分)

接着Pandas教程&#xff08;非常详细&#xff09;&#xff08;第五部分&#xff09;&#xff0c;继续讲述。 三十一、Pandas Excel读写操作详解 Excel 是由微软公司开发的办公软件之一&#xff0c;它在日常工作中得到了广泛的应用。在数据量较少的情况下&#xff0c;Excel 对…

动手学深度学习——序列模型

序列模型 1. 统计工具1.1 自回归模型1.2 马尔可夫模型 2. 训练3. 预测4. 小结 序列模型是一类机器学习模型&#xff0c;用于处理具有时序关系的数据。这些模型被广泛应用于自然语言处理、音频处理、时间序列分析等领域。 以下是几种常见的序列模型&#xff1a; 隐马尔可夫模型…

忘记7-zip密码,如何解压文件?

7z压缩包设置了密码&#xff0c;解压的时候就需要输入正确对密码才能顺利解压出文件&#xff0c;正常当我们解压文件或者删除密码的时候&#xff0c;虽然方法多&#xff0c;但是都需要输入正确的密码才能完成。忘记密码就无法进行操作。 那么&#xff0c;忘记了7z压缩包的密码…

字符流的讲解 以及 Reader和Writer的用法

文章目录 ❤专栏导读❤字符流❤Reader类的操作 ❤Writer类操作❤Writer类的构造方法 ❤专栏导读 &#x1f680;《多线程》 &#x1f680;《数据结构剖析》 &#x1f680;《JavaSE语法》 在Java标准库中&#xff0c;提供的读写文件的流对象有很多很多的类&#xff0c;但是可以将…

盘点49个Python网站项目Python爱好者不容错过

盘点49个Python网站项目Python爱好者不容错过 学习知识费力气&#xff0c;收集整理更不易。 知识付费甚欢喜&#xff0c;为咱码农谋福利。 链接&#xff1a;https://pan.baidu.com/s/1aFYJtNZjgst1l5KFBckP2A?pwd8888 提取码&#xff1a;8888 项目名称 A simpleshorturl…

C++ vector中capacity()和size() 的区别

文章目录 1 capacity()和size() 介绍2 vector满了之后&#xff0c;capacity()会自动了扩充为原来的2倍 &#xff1f; 1 capacity()和size() 介绍 size是指容器当前拥有元素的个数&#xff0c; capacity是指容器在必须分配新的存储空间之前可以存放的元素总数。 如vector<i…

PasswordPusher:能通过URL安全传递密码

什么是 Password Pusher &#xff1f; Password Pusher 是一个开源应用程序&#xff0c;用于通过网络安全的传递密码。在经过一定数量的查看和/或时间后&#xff0c;指向密码的链接会过期。 从功能上说&#xff0c;类似于 Bitwarden Send&#xff0c;思路上与传统阅后即焚工具一…

智能电网线路阻抗模拟的工作原理

智能电网线路阻抗模拟是一种通过模拟电网线路的阻抗特性来实现电网故障检测和定位的技术。智能电网系统通过安装在电网线路上的传感器&#xff0c;实时采集线路上的电流、电压等参数&#xff0c;并将这些数据传输到监控中心。监控中心接收到传感器采集的数据后&#xff0c;对数…

Java排序算法之贪心算法

贪心算法是一种优化问题的解决方法&#xff0c;它在每一步选择中都采取在当前状态下最好或最优&#xff08;即最有利&#xff09;的选择&#xff0c;从而希望导致结果是全局最优的。贪心算法常用于最优化问题&#xff0c;比如最小生成树、哈夫曼编码、最短路径等。贪心算法是一…

《ThingsBoard从入门到精通》的优秀课程

0、介绍 多年java物联网行业开发&#xff0c;精通物联网平台的架构与设计&#xff0c;精通开源物联网平台ThingsBoard&#xff0c;ThingsBoard专家。最近出了一套《ThingsBoard从入门到精通》的全套课程&#xff0c;只要学习了这一套课程&#xff0c;你将随便驾驭ThingsBoard。…

.net core windows 最详细步骤,傻瓜式如何安装rabbitmq 通知消息中间件

本次安装环境信息&#xff1a; 系统&#xff1a;win11 64位专业版 erlang rabbitMQ 一、下载安装程序 rabbitMQ安装程序下载路径&#xff1a;Installing on Windows — RabbitMQ 不能下载使用 Index of /download/ (erlang.org) otp_win64_22.0.exe

Qt图形视图框架:QGraphicsItem详解

Qt图形视图框架&#xff1a;QGraphicsItem详解 Chapter1 Qt图形视图框架&#xff1a;QGraphicsItem详解Chapter2 自定义QGraphicsItem实现平移、改变尺寸和旋转1. 平移2. 改变尺寸3. 旋转完整代码如下&#xff1a;头文件源文件 Chapter1 Qt图形视图框架&#xff1a;QGraphicsIt…

docker部署Prometheus+Cadvisor+Grafana实现服务器监控

一&#xff1a;Prometheus 1&#xff1a;介绍&#xff1a; Prometheus是一个在SoundCloud上构建的开源系统监视和警报工具包 2&#xff1a;特点 多维度数据模型-由指标键值对标识的时间序列数据组成&#xff1b;PromQL&#xff0c;一种灵活的查询语言&#xff1b;不依赖分布…