gateway 微服务的入口-笔记

本文属于b站图灵课堂springcloud笔记系列。讲的好还不要钱,值得推荐。

为什么需要API网关?

  • 客户端多次请求不同的微服务,会增加客户端代码和配置的复杂性,维护成本比价高
  • 认证复杂,每个微服务可能存在不同的认证方式,客户端去调用,要去适配不同的认证
  • 存在跨域的请求,调用链有一定的相对复杂性(防火墙 / 浏览器不友好的协议)
  • 难以重构,随着项目的迭代,可能需要重新划分微服务

为了解决上面的问题,引入了API网关

Spring Cloud Gateway 是什么?

This project provides an API Gateway built on top of the Spring Ecosystem, including: Spring 6, Spring Boot 3 and Project Reactor. Spring Cloud Gateway aims to provide a simple, yet effective way to route to APIs and provide cross cutting concerns to them such as: security, monitoring/metrics, and resiliency.

There are two distinct flavors of Spring Cloud Gateway: Server and Proxy Exchange. Each flavor offers WebFlux and MVC compatibility.

  • The Server variant is a full-featured API gateway that can be standalone or embedded in a Spring Boot application.

  • The Proxy Exchange variant is exclusively for use in annotation based WebFlux or MVC applications and allows the use of a special ProxyExchange object as a parameter to a web handler method.

就是spring cloud 官方推出的第二代网关,是由 WebFlux + Netty + Reactor 实现的响应式的 API 网关。

特性:

  • Java 17

  • Spring Framework 6

  • Spring Boot 3

  • Dynamic routing

  • Route matching built into Spring Handler Mapping

  • Route matching on HTTP Request (Path, Method, Header, Host, etc...​)

  • Filters scoped to Matching Route

  • Filters can modify downstream HTTP Request and HTTP Response (Add/Remove Headers, Add/Remove Parameters, Rewrite Path, Set Path, Hystrix, etc...​)

  • API or configuration driven

  • Supports Spring Cloud DiscoveryClient for configuring Routes

其余详细介绍请看GitHub - spring-cloud/spring-cloud-gateway: An API Gateway built on Spring Framework and Spring Boot providing routing and more.

行业中通常把网关分为两个大类:流量网关与业务网关,流量网关主要提供全局性的、与后端业务无关的策略配置,如NG,随着应用架构模式从单体演进到现在的分布式微服务,业务网关也有了新的叫法 - 微服务网关,比如gateway.当然阿里也有开源的Higress实现了流量网关 + 微服务网关 + 安全网关高度集成的功能,这是一种发展趋势。

微服务接入gateway

新建一个模块,就是一个一个启动类

核心配置,pom引入gateway依赖

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

        <!--nacos-discovery  注册中心依赖-->
        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
        </dependency>

        <!-- loadbalancer 负载均衡器依赖-->
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-loadbalancer</artifactId>
        </dependency>

配置文件:application.yml 如下

server:
  port: 18888

spring:
  application:
    name: tlmall-gateway
  cloud:
    nacos:
#      discovery:
#        server-addr: tlmall-nacos-server:8848
      config:
        server-addr: tlmall-nacos-server:8848
        file-extension: yml   #指定配置文件扩展名为yml

#    gateway:
#      #设置路由:路由id、路由到微服务的uri、断言
#      routes:
#        - id: order_route  #路由ID,全局唯一,建议配置服务名
#          uri: lb://tlmall-order  #lb 整合负载均衡器loadbalancer
#          predicates:
#            - Path=/order/**   # 断言,路径相匹配的进行路由
#
#        - id: storage_route   #路由ID,全局唯一,建议配置服务名
#          uri: lb://tlmall-storage  #lb 整合负载均衡器loadbalancer
#          predicates:
#            - Path=/storage/**   # 断言,路径相匹配的进行路由
#
#        - id: account_route   #路由ID,全局唯一,建议配置服务名
#          uri: lb://tlmall-account  #lb 整合负载均衡器loadbalancer
#          predicates:
#            - Path=/account/**   # 断言,路径相匹配的进行路由

  config:
    import:
      - optional:nacos:${spring.application.name}.yml
      - nacos:nacos-discovery.yml

注释掉内容抽取到nacos, Nacos配置中心创建一个dataId为tlmall-gateway.yml的配置,导入网关的配置.

测试:

启动网关服务。

修改postman,改用网关地址下单:http://127.0.0.1:18888/order/create

修改页面地址,order.html中访问地址都替换为tmall-gateway:18888,测试下单是否成功

小结:gateway可以实现微服务中流量入口。

相关推荐
dal118网工任子仪3 小时前
66,【6】buuctf web [HarekazeCTF2019]Avatar Uploader 1
笔记·学习
羊小猪~~4 小时前
MYSQL学习笔记(四):多表关系、多表查询(交叉连接、内连接、外连接、自连接)、七种JSONS、集合
数据库·笔记·后端·sql·学习·mysql·考研
milk_yan5 小时前
Docker集成onlyoffice实现预览功能
前端·笔记·docker
东京老树根5 小时前
Excel 技巧15 - 在Excel中抠图头像,换背景色(★★)
笔记·学习·excel
黄名富6 小时前
Kafka 日志存储 — 日志索引
java·分布式·微服务·kafka
Ronin-Lotus6 小时前
嵌入式硬件篇---ADC模拟-数字转换
笔记·stm32·单片机·嵌入式硬件·学习·低代码·模块测试
UQI-LIUWJ7 小时前
LLM笔记:LayerNorm VS RMSNorm
笔记
东京老树根8 小时前
Excel 技巧17 - 如何计算倒计时,并添加该倒计时的数据条(★)
笔记·学习·excel
m0_748240549 小时前
AutoSar架构学习笔记
笔记·学习·架构
siy233311 小时前
[c语言日寄]结构体的使用及其拓展
c语言·开发语言·笔记·学习·算法