Gateway网关

网关GateWay

官方文档:https://docs.spring.io/spring-cloud-gateway/docs/3.1.2/reference/html/#gateway-how-it-works

核心概念

  • 路由: 网关的核心数据结构,定义了网关如何处理请求. 一条路由信息包含路由的唯一标识ID,目的地URI, 一组断言(用于判断当前请求是否匹配这条路由信息), 以及一组过滤器组成. 当网关收到一个请求时,如果某条路由信息的所有断言都为真,那么改请求匹配这条路由,会被发往改路由的目的uri。
  • 断言: 可以根据Http请求的路径,请求头或者请求参数对于一个请求进行路由匹配判断。
  • 过滤器: 当请求匹配上某个路由信息时,由配置的过滤器依次处理。

网关节点搭建

引入依赖

<dependencies><!--   引入nacos 注册中心依赖  注册服务   --><dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId></dependency>
<!--    gateway网关的依赖,注意,不要引用 starter-web依赖,否则启动报错    --><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-gateway</artifactId></dependency>
<!--     这个依赖可以查看网关的路由信息   --><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-actuator</artifactId></dependency></dependencies>

启动类

package com.qf.gateway;import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.client.discovery.EnableDiscoveryClient;@SpringBootApplication
@EnableDiscoveryClient
public class GateWayApp {public static void main(String[] args) {SpringApplication.run(GateWayApp.class,args);}
}

配置文件

server:port: 80
spring:application:             #这是注册在注册中心的服务名name: service-gatewaycloud:nacos:discovery:   #注册中心的地址server-addr: 127.0.0.1:8848gateway:# 打开如下配置,自动发现 Nacos 注册中心的服务,并自动生成路由信息discovery:locator:enabled: truelower-case-service-id: true  # 让网关自动生成的服务名为小写routes:- id: aa# 断言的作用,判断网关收到的请求是否匹配当前的路由信息predicates:- Path=/pro/**filters:  # 重写Url 去掉pro- RewritePath=/pro/?(?<segment>.*), /$\{segment}uri: lb://service-provide  #lb代表 负载均衡  写服务名- id: ss# 断言的作用,判断网关收到的请求是否匹配当前的路由信息predicates:- Path=/sss/**filters:- RewritePath=/sss/?(?<segment>.*), /$\{segment}uri: http://localhost:8081/- id: baidu# 断言的作用,判断网关收到的请求是否匹配当前的路由信息predicates:- Path=/baidu/jmj/lll/**filters:# 去掉前缀几个 /**- StripPrefix=3uri: http://www.baidu.com#开启 监控功能#开启 监控功能  http://localhost/actuator/gateway/routes
management:endpoints:enabled-by-default: true #暴露所有端点信息web:exposure:include: '*'  #以web方式暴露

查看路由信息

http://localhost/actuator/gateway/routes

手动添加路由信息

spring:cloud:gateway:routes:- id: baidu# 断言的作用,判断网关收到的请求是否匹配当前的路由信息 predicates:- Path=/**uri: http://www.baidu.com

尝试发送如下请求,并观察响应结果

http://localhost/s?wd=onepiece

添加路由信息到内部微服务

将路径/sss的请求发送给micro1微服务处理

spring:cloud:gateway:routes:- id: micro1predicates:- Path=/sss/**uri: http://localhost:9100/- id: baidupredicates:- Path=/**uri: http://www.baidu.com

在这里插入图片描述

错误原因分析,在micro1节点观察日志,请求路径为 /sss/test1。

在这里插入图片描述

解决办法:使用gateway提供的URL重写功能。配置url重写过滤器。

URL重写

当断言为true时,gateway会把当前请求路径完整的发送给后端uri,因此需要特别注意后端实际的接口地址是否匹配。

例如,后端真实接口地址为:http://localhost:8900/test1

那么,gateway真正转发给后端的请求为http://localhost:8900/sss/test1。

如果需要,可以重写发送给后端接口的真实uri路径。代码如下:

当匹配sss路径的请求发送给网关时,真正转发的路径去掉了sss,仅仅保留后面的路径信息

spring:cloud:gateway:routes:- id: micro1predicates:- Path=/sss/**filters:- RewritePath=/sss/?(?<segment>.*), /$\{segment}uri: http://localhost:9100/- id: baidupredicates:- Path=/**uri: http://www.baidu.com

或者使用内置过滤器实现URL重写

spring:cloud:gateway:routes:- id: baidupredicates:- Path=/baidu/**# 内置过滤器 StripPrefix,可以去掉Path中的前n个前缀(n为StripPrefix配置的值) filters:- StripPrefix=1uri: http://www.baidu.com

负载均衡调用内部微服务

uri: lb://micro1 , 双斜线后面写微服务的名称

spring:application:name: gatewaycloud:gateway:routes:- id: micro1predicates:- Path=/sss/**filters:- RewritePath=/sss/?(?<segment>.*), /$\{segment}uri: lb://micro1

整合Nacos自动生成微服务路由信息

注意:如果gateway想要自动生成eureka中注册服务的路由信息,需要开启如下配置:

spring:cloud:gateway:# 打开如下配置,自动发现eureka注册中心的服务,并自动生成路由信息      discovery:locator:enabled: true lower-case-service-id: true  # 让网关自动生成的服务名为小写

http://localhost/actuator/gateway/routes

断言配置

spring:cloud:gateway:routes:- id: searchuri: lb://micro1  #服务名predicates:- Path=/sss/**- After=2022-01-20T17:42:47.789-07:00[America/Denver] # 还有一个Before - Cookie=chocolate, ch.p   #cookie  chocolate=chop- Header=X-Request-Id, \d+  # 请求头里   X-Request-Id= 1-任意个(0-9)的整数filters:- RewritePath=/sss/?(?<segment>.*), /$\{segment}

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

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

相关文章

Vue3 封装 element-plus 图标选择器

一、实现效果 二、实现步骤 2.1. 全局注册 icon 组件 // main.ts import App from ./App.vue; import { createApp } from vue; import * as ElementPlusIconsVue from element-plus/icons-vueconst app createApp(App);// 全局挂载和注册 element-plus 的所有 icon app.con…

基于Java+SpringBoot+Vue物流管理小程序系统的设计与实现 前后端分离【Java毕业设计·文档报告·代码讲解·安装调试】

&#x1f34a;作者&#xff1a;计算机编程-吉哥 &#x1f34a;简介&#xff1a;专业从事JavaWeb程序开发&#xff0c;微信小程序开发&#xff0c;定制化项目、 源码、代码讲解、文档撰写、ppt制作。做自己喜欢的事&#xff0c;生活就是快乐的。 &#x1f34a;心愿&#xff1a;点…

什么是领域驱动设计(DDD): 领域驱动设计和实践如何做

引言 软件系统面向对象的设计思想可谓历史悠久&#xff0c;20 世纪 70 年代的 Smalltalk 可以说是面向对象语言的经典&#xff0c;直到今天我们依然将这门语言视为面向对象语言的基础。随着编程语言和技术的发展&#xff0c;各种语言特性层出不穷&#xff0c;面向对象是大部分…

大数据 Hive 数据仓库介绍

目录 一、​​数据仓库概念 二、场景案例&#xff1a;数据仓库为何而来&#xff1f; 2.1 操作型记录的保存 2.2 分析型决策的制定 2.3 OLTP 环境开展分析可行吗&#xff1f; 2.4 数据仓库的构建 三、数据仓库主要特征 3.1 面向主题性&#xff08;Subject-Orient…

【Web开发 | Django】数据库分流之道:探索Django多数据库路由最佳实践

&#x1f935;‍♂️ 个人主页: AI_magician &#x1f4e1;主页地址&#xff1a; 作者简介&#xff1a;CSDN内容合伙人&#xff0c;全栈领域优质创作者。 &#x1f468;‍&#x1f4bb;景愿&#xff1a;旨在于能和更多的热爱计算机的伙伴一起成长&#xff01;&#xff01;&…

iOS线上闪退问题解决方案

iOS线上闪退问题的收集工具是关键&#xff0c;它们可以帮助你及时发现和解决应用程序中的崩溃问题。以下是一些常用的iOS线上闪退问题收集工具及其使用方法&#xff0c;希望对大家有所帮助。北京木奇移动技术有限公司&#xff0c;专业的软件外包开发公司&#xff0c;欢迎交流合…

绘图系统六:动态三维展示

文章目录 时间轴单帧跳转动图绘制函数接口优化 &#x1f4c8;一 三维绘图系统 &#x1f4c8;二 多图绘制系统&#x1f4c8;三 坐 标 轴 定 制&#x1f4c8;四 定制绘图风格 &#x1f4c8;五 数据生成导入源码地址 Python打造动态绘图系统 时间轴 三维并不是人类理解的极限&am…

精品Python数字藏品购物商城爬虫-可视化大屏

《[含文档PPT源码等]精品基于Python实现的数字藏品爬虫》该项目含有源码、文档、PPT、配套开发软件、软件安装教程、项目发布教程等 软件开发环境及开发工具&#xff1a; 开发语言&#xff1a;python 使用框架&#xff1a;Django 前端技术&#xff1a;JavaScript、VUE.js&a…

PHP-composer安装扩展安装,批量操作合并pdf

清除Composer缓存&#xff1a; 运行以下命令来清除Composer的缓存&#xff0c;并再次尝试安装包。 bash composer clear-cache 使用不同的镜像源&#xff1a; Composer使用的默认包源可能会受到限制或访问问题。你可以切换到使用其他镜像源&#xff0c;如阿里云、Composer中国…

Nginx之gzip模块解读

目录 gzip基本介绍 gzip工作原理 Nginx中的gzip 不建议开启Nginx中的gzip场景 gzip基本介绍 gzip是GNUzip的缩写&#xff0c;最早用于UNIX系统的文件压缩。HTTP协议上的gzip编码是一种用来改进web应用程序性能的技术&#xff0c;web服务器和客户端&#xff08;浏览器&…

科目三基础四项(一)

​ 第一天&#xff0c;基础操作&#xff0c;仪表&#xff0c;方向&#xff0c;挡位 按照模块来 1、方向盘两手在两侧 ​ 编辑 转向时的角度&#xff0c;只用&#xff1a;向左540&#xff0c;向右180 向左打和向右打的角度要抵消&#xff0c;回正 掉头向左打满再回 注意…

【STM32】IAP升级 预备知识

IAP&#xff08;In Application Programming&#xff09;简介 Flash够大的情况下&#xff0c;上电后的程序通过修改 MSP 的方式&#xff0c;可以在一块Flash上存在多个功能差异的程序。 IAP是为了在执行正常功能前&#xff0c;为了升级功能&#xff0c;提前运行的一段程序。这…

微软在Windows 11推出Copilot,将DALL-E 3集成在Bing!

美东时间9月21日&#xff0c;微软在美国纽约曼哈顿举办产品发布会&#xff0c;生成式AI成为重要主题之一。 微软表示&#xff0c;Copilot将于9月26日在Windows 11中推出&#xff1b;Microsoft 365 Copilot 将于11 月1日向企业客户全面推出&#xff1b;将OpenAI最新的文本生成图…

C# OpenCvSharp 图片模糊检测(拉普拉斯算子)

效果 项目 代码 using OpenCvSharp; using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Drawing; using System.Linq; using System.Text; using System.Windows.Forms; using System.Windows.Forms.VisualStyl…

二叉树层序遍历及判断完全二叉树

个人主页:Lei宝啊 愿所有美好如期而遇 目录 二叉树层序遍历&#xff1a; 判断完全二叉树&#xff1a; 二叉树层序遍历&#xff1a; 层序遍历就是一层一层&#xff0c;从上到下遍历&#xff0c;上图遍历结果为&#xff1a;4 2 7 1 3 6 9 思路&#xff1a; 通过队列来实现层序…

vue下载Excel文件

前端vue实现导出Excel文件 用到的是 上代码 var wb XLSX.utils.table_to_book(document.querySelector(#my-table));//关联dom节点 这个是表格绑定的id名称var wbout XLSX.write(wb, {bookType: xlsx,bookSST: true,type: array})try {FileSaver.saveAs(new Blob([wbout], {…

Win10专业版开启远程桌面

Win10专业版开启远程桌面 方法一&#xff1a; 一、按“Win R”键&#xff0c;然后输入“sysdm.cpl”并按下回车键打开系统属性。 二、选择“远程”选项卡&#xff0c;在远程桌面中勾选“允许远程连接到此计算机”就可以开启远程桌面&#xff1b; 方法二&#xff1a; 一、打…

Mybatis 映射器与XML配置职责分离

之前我们介绍了使用XML配置方式完成对数据的增删改查操作&#xff0c;使用此方式在实际调用时需要使用【命名空间.标签编号】的方式执行&#xff0c;此方式在编写SQL语句时很方便&#xff0c;而在执行SQL语句环节就显得不太优雅&#xff1b;另外我们也介绍了使用映射器完成对数…

杂记 | 使用gitlab-runner将python项目以docker镜像方式流水线部署到服务器(解决部署缓慢和时区不对的问题)

文章目录 01 需求背景1.1 需求1.2 步骤 02 编写BaseDockerfile2.1 编写2.2 说明2.3 执行 03 编写Dockerfile04 编写.gitlab-ci.yml05 项目结构 01 需求背景 1.1 需求 我有一个python项目&#xff0c;该项目可能是一个服务器监控程序&#xff0c;也可能是一个后端程序&#xf…

ChatGLM GPT原理介绍

图解GPT 除了BERT以外,另一个预训练模型GPT也给NLP领域带来了不少轰动,本节也对GPT做一个详细的讲解。 OpenAI提出的GPT-2模型(https://openai.com/blog/better-language-models/) 能够写出连贯并且高质量的文章,比之前语言模型效果好很多。GPT-2是基于Transformer搭建的,相…