【Spring Cloud】Gateway的配置与使用

文章目录

前言

Gateway其实是springcloud 原生的东西,但是我还是想放在这里讲,因为我们使用nacos时,前端调用服务之后,一般会调用到我们的网关上面,然后网关选择我们的nacos服务,再调用后端的服务

在当今微服务架构中,网关起着至关重要的角色。它充当着应用程序和外部世界之间的门户,处理来自客户端的请求并将其转发到适当的微服务。而Spring Cloud Gateway作为Spring Cloud生态系统中的一员,为我们提供了一个强大而灵活的网关解决方案。

本文将深入探讨Spring Cloud Gateway的配置与使用,帮助读者更好地理解并应用这个优秀的网关工具。

第一步,创建一个springboot工程

第二步,添加依赖

xml 复制代码
  <properties>
        <java.version>1.8</java.version>
        <spring-cloud.version>Greenwich.SR6</spring-cloud.version>
        <spring-cloud-alibaba.version>2.1.0.RELEASE</spring-cloud-alibaba.version>
    </properties>

    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter</artifactId>
        </dependency>

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-gateway</artifactId>
        </dependency>
        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
        </dependency>
    </dependencies>

    <dependencyManagement>
        <dependencies>
            <dependency>
                <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-dependencies</artifactId>
                <version>${spring-cloud.version}</version>
                <type>pom</type>
                <scope>import</scope>
            </dependency>
            <dependency>
                <groupId>com.alibaba.cloud</groupId>
                <artifactId>spring-cloud-alibaba-dependencies</artifactId>
                <version>${spring-cloud-alibaba.version}</version>
                <type>pom</type>
                <scope>import</scope>
            </dependency>
        </dependencies>
    </dependencyManagement>

第三步,编写yml文件

yaml 复制代码
spring:
  cloud:
    nacos:
      discovery:
        server-addr: 192.168.0.93:8848
    gateway:
      routes:
        - id: service-provider
          uri: lb://service-provider
          predicates:
            - Path=/provider/** #以provider开头的请求都负载到provider服务
          filters:
            - RewritePath=/provider/(?<segment>.*), /$\{segment} #过滤掉url里的provider,例如http://ip:port/provider/getCity -> http://ip:port/getCity
  application:
    name: gateway
server:
  port: 8999

解读配置文件:

  • RewritePath:过滤掉url里的provider,例如http://ip:port/provider/getCity -> http://ip:port/getCity
  • Path:以provider开头的请求都负载到provider服务
  • id:route的唯一id
  • uri:需要返回的nacos中间的服务

这是我们的nacos控制台,里面有一个service-provider服务,他负责提供api

所以yml里面的routes我们配置uri为lb://service-provider

假如前端要访问我们的服务,他只需要访问http://localhost:8999/provider就好,他是以provider开头,所以

Path这里我们配置为- Path=/provider/**

但是我们服务提供者提供的api为/echo/{string},所以我们需要去掉provider,因此RewritePath配置为/provider/(?<segment>.*), /$\{segment}

第四步,启动主启动类

之后网关服务就会被注册到nacos中

然后就可以通过我们的gateway服务访问我们nacos中的服务了

提供者提供的api如下

官网:

总结

通过本文的介绍,我们了解了Spring Cloud Gateway的核心概念和基本配置。它的灵活性和可扩展性使得它成为构建可靠、高性能微服务架构的理想选择。

希望本文对于读者们在使用Spring Cloud Gateway时有所帮助,并能够加深对该组件的理解和运用。愿您在未来的项目中,能够借助Spring Cloud Gateway轻松实现安全、高效的网关服务。

相关推荐
云攀登者-望正茂2 小时前
通过AWS WAF Rate limit rule来保护API Gateway
网络·gateway·aws
在荒野的梦想3 小时前
若依微服务集成Flowable仿钉钉工作流
spring cloud·微服务·钉钉
小杨4049 小时前
springboot框架项目实践应用十八(nacos高级特性)
spring boot·后端·spring cloud
magic 24510 小时前
MyBatis的缓存、逆向工程、使用PageHelper、使用PageHelper
java·spring·maven·mybatis
Alt.911 小时前
SpringMVC基础一(SpringMVC运行原理)
数据库·spring·mvc
LCY13312 小时前
docker 常用指令整理
java·后端·spring
ℳ₯㎕ddzོꦿ࿐12 小时前
Spring Boot 中集成 Knife4j:解决文件上传不显示文件域的问题
java·spring boot·spring
SoFlu软件机器人14 小时前
AI 重构 Java 遗留系统:从静态方法到 Spring Bean 注入的自动化升级
java·spring·重构
崔lc14 小时前
在idea中看spring源码
ide·spring·intellij-idea
遇见你真好。14 小时前
flowable任务监听器和java-service依赖注入问题
spring·springboot·flowable