(四)Spring Cloud Alibaba 2023.x:高效构建 Gateway 网关服务

news/2025/3/12 15:46:03/

目录

前言

准备

项目集成

pom.xml引入依赖

启动类

yml文件添加网关配置

修改消费者FeignService类

结果验证


前言

Spring cloud alibaba 体系中构建微服务,我们使用Spring Cloud Gateway 作为服务网关, Gateway是Spring 官方推出的一款基于 WebFlux 的高性能、轻量级网关框架,支持动态路由、限流熔断、过滤器链等功能,且与 Spring 生态深度集成,易于上手并具有广泛的社区支持 。

Tips!

为什么不使用阿里系的网关 Higress ,而是选择spring cloud>spring cloud gateway?
        Alibaba 没有重复造轮子去开发一个类似 Gateway 的通用网关,而是专注于更前沿的 云原生场景,打造了 Higress。Higress 针对 Kubernetes 场景进行了深度优化,支持 Istio、服务网格等技术,是为云原生时代的分布式服务架构量身定制的网关解决方案。

        Spring Cloud Gateway 已经是一个非常成熟和高效的网关解决方案,能够满足大多数微服务场景的需求,与Spring 生态的深度整合,适配性和易用性都非常优秀。因此,在传统的 Spring 微服务体系中,使用 Gateway 已经足够。

        这种明确的分工让两者在各自的场景中都发挥了最大优势,而不是功能上的重复建设。在spring cloud>spring cloud alibaba 的官方github试例代码中也是使用的Gateway。

准备

源码获取:GitHub - RemainderTime/spring-cloud-alibaba-base-demo: 基于spring cloud>spring cloud alibaba生态快速构建微服务脚手架

项目集成

创建一个网关服务:cloud-gateway

那么目前有三个服务项目:

pom.xml引入依赖

在网关服务gateway中引入依赖

<!-- API网关 gateway-->
<dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-gateway</artifactId>
</dependency>
<!-- Spring Boot Actuator -->
<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-actuator</artifactId>
</dependency>
<!-- 负载均衡 loadbalancer -->
<dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-loadbalancer</artifactId>
</dependency>

启动类

启动类上依然加上注解@EnableDiscoveryClient作为一个服务注册到nacos中

yml文件添加网关配置

server:port: 9090
spring:application:name: cloud-gateway  # 网关服务的名称cloud:gateway:discovery:locator:enabled: true  # 开启自动服务发现routes:- id: http-producer-routeuri: lb://http-cloud-producer #生产者服务名称predicates:- Path=/test/**  # 匹配路径 /test/...
#          filters:
#            - RewritePath=/test/(?<segment>.*), /test/feign/${segment}  # 重写为生产者的接口路径

uri:这个属性为生产者在注册中心的服务名称

Path:这个属性为生产者提供的接口路径路由

注册中心配置相关和前面服务一样,可参考前面的nacos集成篇

修改消费者FeignService类

@FeignClient(name = "cloud-gateway")
public interface FeignService {}

主要就是修改注解中的服务名称,将之前的生产者服务名称修改为网关的服务名称。

消费者向请求网关服务,在通过网关服务路由转发到生产者

结果验证


至此网关配置成功了


http://www.ppmy.cn/news/1556358.html

相关文章

机器视觉检测相机选型基础知识 | 颜色 | 光源 | 镜头 | 分辨率 / 精度 / 公差

注&#xff1a;本文为 “keyence 视觉沙龙中机器视觉检测的基础知识” 文章合辑。 机器视觉检测基础知识&#xff08;一&#xff09;颜色篇 视觉检测硬件构成的基本部分包括&#xff1a;处理器、相机、镜头、光源。其中&#xff0c;和光源相关的最重要的两个参数就是光源颜色和…

音视频入门基础:MPEG2-TS专题(17)——FFmpeg源码中,解析TS program map section的实现

一、引言 由《音视频入门基础&#xff1a;MPEG2-TS专题&#xff08;16&#xff09;——PMT简介》可以知道&#xff0c;PMT表&#xff08;Program map table&#xff09;由一个或多个段&#xff08;Transport stream program map section&#xff0c;简称TS program map sectio…

Apache solr XML 实体注入漏洞

描述&#xff1a; Apache Solr 是一个开源的搜索服务器。Solr 使用 Java 语言开发&#xff0c;主要基于 HTTP 和 Apache Lucene 实现。原理大致是文档通过Http利用XML加到一个搜索集合中。查询该集合也是通过 http收到一个XML/JSON响应来实现。此次7.1.0之前版本总共爆出两个漏…

蓝桥杯算法训练 黑色星期五C++

题目描述 有些西方人比较迷信&#xff0c;如果某个月的13号正好是星期五&#xff0c;他们就会觉得不太吉利&#xff0c;用古人的说法&#xff0c;就是“诸事不宜”。请你编写一个程序&#xff0c;统计出在某个特定的年份中&#xff0c;出现了多少次既是13号又是星期五的情形&am…

安灯系统自动化车间设备故障快速响应目视化管理

一、安灯系统概述与核心功能 在自动化车间的高效运作中&#xff0c;设备故障的快速响应至关重要。安灯系统作为一款融合软件与硬件的智能化解决方案应运而生。其核心功能在于实时掌握机台与工位状态&#xff0c;达成生产管理的透明化。通过与多种硬件设备协同&#xff0c;如标…

sentinel 限流保护-笔记

本文属于b站图灵课堂springcloud笔记系列。讲的好还不要钱&#xff0c;值得推荐。 为什么要引入限流组件&#xff1f; 在微服务环境下&#xff0c;服务之间存在复杂的调用关系&#xff0c;单个服务的故障或过载可能会迅速影响到整个系统&#xff0c;导致服务雪崩效应。流控组件…

用github镜像加速, --recursive还是去github站怎么处理?

小伙伴们大多碰到过github抽风的情况&#xff0c;时通时断&#xff0c;时快时慢&#xff0c;非常考验心情。 以前碰到连不上的时候&#xff0c;我大多就是在gitee和gitcode网站找一下镜像&#xff0c;找到后直接git clone 新地址即可。但是碰到 --recursive的时候就不行了&…

PostgreSQL的学习心得和知识总结(一百六十四)|深入理解PostgreSQL数据库之在 libpq 中支持负载平衡

目录结构 注&#xff1a;提前言明 本文借鉴了以下博主、书籍或网站的内容&#xff0c;其列表如下&#xff1a; 1、参考书籍&#xff1a;《PostgreSQL数据库内核分析》 2、参考书籍&#xff1a;《数据库事务处理的艺术&#xff1a;事务管理与并发控制》 3、PostgreSQL数据库仓库…