spring cloud gateway实践

本文涉及的产品
应用型负载均衡 ALB,每月750个小时 15LCU
传统型负载均衡 CLB,每月750个小时 15LCU
网络型负载均衡 NLB,每月750个小时 15LCU
简介: 一、前言     gateway是spring cloud全家桶的一员,主要用作微服务的网关,是spring官方基于spring5.0,spring boot 2.0和project reactor等技术开发的网关服务,旨在为微服务提供一种简单有效的统一api路由管理方式,基于filter链的方式提供了网关的基本功能如安全、监控、埋点、限流等。    

一、前言

    gateway是spring cloud全家桶的一员,主要用作微服务的网关,是spring官方基于spring5.0,spring boot 2.0和project reactor等技术开发的网关服务,旨在为微服务提供一种简单有效的统一api路由管理方式,基于filter链的方式提供了网关的基本功能如安全、监控、埋点、限流等。

    项目地址:https://spring.io/projects/spring-cloud-gateway

二、使用

    1、依赖

    spring cloud已集成gateway,只需要引入spring cloud的父pom,就能直接使用。

<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>
        </dependencies>
</dependencyManagement>
<dependencies>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-gateway</artifactId>
        </dependency>
</dependencies>
AI 代码解读

       2、路由配置

     spring cloud gateway支持两种路由配置:yaml文件配置和代码配置。

    (1)代码配置

       在主程序中使用代码配置路由,官方示例如下:

@SpringBootApplication
public class DemogatewayApplication {
	@Bean
	public RouteLocator customRouteLocator(RouteLocatorBuilder builder) {
		return builder.routes()
			.route("path_route", r -> r.path("/get")
				.uri("http://httpbin.org"))
			.route("host_route", r -> r.host("*.myhost.org")
				.uri("http://httpbin.org"))
			.route("rewrite_route", r -> r.host("*.rewrite.org")
				.filters(f -> f.rewritePath("/foo/(?<segment>.*)", "/${segment}"))
				.uri("http://httpbin.org"))
			.route("hystrix_route", r -> r.host("*.hystrix.org")
				.filters(f -> f.hystrix(c -> c.setName("slowcmd")))
				.uri("http://httpbin.org"))
			.route("hystrix_fallback_route", r -> r.host("*.hystrixfallback.org")
				.filters(f -> f.hystrix(c -> c.setName("slowcmd").setFallbackUri("forward:/hystrixfallback")))
				.uri("http://httpbin.org"))
			.route("limit_route", r -> r
				.host("*.limited.org").and().path("/anything/**")
				.filters(f -> f.requestRateLimiter(c -> c.setRateLimiter(redisRateLimiter())))
				.uri("http://httpbin.org"))
			.build();
	}
}
AI 代码解读

    (2)yaml文件配置

    yaml文件是spring推荐使用的方式,使用上比较直观,以下是我们项目中的配置:

project:
  name: my-gateway

# endpoint配置
management:
  endpoints:
    web:
      exposure:
        include: "*"
  server:
    port: 7002

# http服务器端口
server:
  port: 7001

spring:
  application:
    name: ${project.name}
  profiles:
    active: testing
  hsf:
    group: my
    version: 1.0.0.DAILY
    timeout: 2000

  cloud:
    gateway:
      discovery:
        locator:
          enabled: true
          lower-case-service-id: true
      # 跨域
      globalcors:
        corsConfigurations:
          '[/**]':
            allowedHeaders: "*"
            allowedOrigins: "*"
            allowedMethods:
            - GET
              POST
              DELETE
              PUT
              OPTION


      routes:
        # 数据应用
        - id: my-data-app
          uri: lb://my-data-app
          predicates:
          - Path=/my-data-app/**
          filters:
          - StripPrefix=1
        # 数据应用websocket接口
        - id: my-data-app-websocket
          uri: lb:ws://my-data-app
          predicates:
          - Path=/my-data-app/**
          filters:
          - StripPrefix=1

        # 任务调度
        - id: my-task-scheduler
          uri: lb://my-task-scheduler
          predicates:
          - Path=/my-task-scheduler/**
          filters:
          - StripPrefix=1

        # 流程跟踪
        - id: my-process-tracking
          uri: lb://my-process-tracking
          predicates:
          - Path=/my-process-tracking/**
          filters:
          - StripPrefix=1

        # 软件产品质量
        - id: my-app-quality
          uri: lb://my-app-quality
          predicates:
          - Path=/my-app-quality/**
          filters:
          - StripPrefix=1

        # 工程效率质量
        - id: my-project-quality
          uri: lb://my-project-quality
          predicates:
          - Path=/my-project-quality/**
          filters:
          - StripPrefix=1

        # 在线产品质量
        - id: my-online-quality
          uri: lb://my-online-quality
          predicates:
          - Path=/my-online-quality/**
          filters:
          - StripPrefix=1

        # 数据存储
        - id: my-data-storage
          uri: lb://my-data-storage
          predicates:
          - Path=/my-data-storage/**
          filters:
          - StripPrefix=1

        # 数据收容
        - id: dcpp-query
          uri: lb://dcpp-query
          predicates:
          - Path=/dcpp-query/**
          filters:
          - StripPrefix=1

logging:
  level:
    org.springframework.cloud.gateway: DEBUG
    org.springframework.http.server.reactive: DEBUG
    org.springframework.web.reactive: DEBUG
AI 代码解读

    id:每个route的唯一标识,如果不填写则为uuid

    uri:转发的url,即最终访问的后端服务地址,如果lb开头则为服务注册中心上的服务地址

    predicates:断言匹配器,根据规则进行匹配。

    参考:https://cloud.spring.io/spring-cloud-gateway/spring-cloud-gateway.html#gateway-request-predicates-factories

三、实践

    1、Nacos作为服务注册中心

    (1)添加nacos依赖,并在启动类中开启服务发现配置

@EnableDiscoveryClient
@SpringBootApplication(scanBasePackages = {"com.amap.qinling"})
public class Application {

    public static void main(String[] args) {
        SpringApplication.run(Application.class, args);
    }
}
AI 代码解读

    (2)路由规则按照lb://my-data-app方式进行配置,lb将会按照LoadBalancerClientFilter类进行处理,即根据my-data-app注册中心查找对应的服务host和端口并替换。  

    2、跨域支持

     gateway跨域支持比较方便,只需要在application.yaml配置跨域相关配置即可:

spring:
  cloud:
    gateway:
      discovery:
      # 跨域
      globalcors:
        corsConfigurations:
          '[/**]':
            allowedHeaders: "*"
            allowedOrigins: "*"
            allowedMethods:
            - GET
              POST
              DELETE
              PUT
              OPTION
AI 代码解读

    3、websocket协议转发  

    需要转发的服务为websocket协议时,只需要在路由规则里面添加相应的配置即可:

routes:
        # 数据应用
        - id: my-data-app
          uri: lb://my-data-app
          predicates:
          - Path=/my-data-app/**
          filters:
          - StripPrefix=1
        # 数据应用websocket接口
        - id: my-data-app-websocket
          uri: lb:ws://my-data-app
          predicates:
          - Path=/my-data-app/**
          filters:
          - StripPrefix=1
AI 代码解读

    uri:lb:ws://my-data-app,ws代表websocket协议,gateway匹配到ws开头的地址会自动匹配到这一条路由并转发。

    如果gateway前面有nginx代理,或者转发的后端服务前面也有nginx,需要在每个nginx中添加websocket协议配置,如下:

location / {
        # support webSocket
        proxy_http_version 1.1;
        proxy_set_header Upgrade $http_upgrade;
        proxy_set_header Connection "upgrade";

        if ($request_uri ~ .*\.(txt|gif|jpg|jpeg|png|bmp|swf|js|css)$) {
            access_log off;
        }
        proxy_pass http://127.0.0.1:7001;
    }
AI 代码解读

    

  

相关实践学习
小试牛刀,一键部署电商商城
SAE 仅需一键,极速部署一个微服务电商商城,体验 Serverless 带给您的全托管体验,一起来部署吧!
负载均衡入门与产品使用指南
负载均衡(Server Load Balancer)是对多台云服务器进行流量分发的负载均衡服务,可以通过流量分发扩展应用系统对外的服务能力,通过消除单点故障提升应用系统的可用性。 本课程主要介绍负载均衡的相关技术以及阿里云负载均衡产品的使用方法。
wcplll
+关注
目录
打赏
0
0
0
0
2
分享
相关文章
ACK Gateway with AI Extension:面向Kubernetes大模型推理的智能路由实践
本文介绍了如何利用阿里云容器服务ACK推出的ACK Gateway with AI Extension组件,在Kubernetes环境中为大语言模型(LLM)推理服务提供智能路由和负载均衡能力。文章以部署和优化QwQ-32B模型为例,详细展示了从环境准备到性能测试的完整实践过程。
ACK Gateway with AI Extension:大模型推理的模型灰度实践
本文介绍了如何使用 ACK Gateway with AI Extension 组件在云原生环境中实现大语言模型(LLM)推理服务的灰度发布和流量分发。该组件专为 LLM 推理场景设计,支持四层/七层流量路由,并提供基于模型服务器负载感知的智能负载均衡能力。通过自定义资源(CRD),如 InferencePool 和 InferenceModel,可以灵活配置推理服务的流量策略,包括模型灰度发布和流量镜像。
|
3月前
|
利用Spring Cloud Gateway Predicate优化微服务路由策略
Spring Cloud Gateway 的路由配置中,`predicates`​(断言)用于定义哪些请求应该匹配特定的路由规则。 断言是Gateway在进行路由时,根据具体的请求信息如请求路径、请求方法、请求参数等进行匹配的规则。当一个请求的信息符合断言设置的条件时,Gateway就会将该请求路由到对应的服务上。
230 69
利用Spring Cloud Gateway Predicate优化微服务路由策略
🛡️Spring Boot 3 整合 Spring Cloud Gateway 工程实践
本文介绍了如何使用Spring Cloud Alibaba 2023.0.0.0技术栈构建微服务网关,以应对微服务架构中流量治理与安全管控的复杂性。通过一个包含鉴权服务、文件服务和主服务的项目,详细讲解了网关的整合与功能开发。首先,通过统一路由配置,将所有请求集中到网关进行管理;其次,实现了限流防刷功能,防止恶意刷接口;最后,添加了登录鉴权机制,确保用户身份验证。整个过程结合Nacos注册中心,确保服务注册与配置管理的高效性。通过这些实践,帮助开发者更好地理解和应用微服务网关。
96 0
🛡️Spring Boot 3 整合 Spring Cloud Gateway 工程实践
微服务架构设计与实践:用Spring Cloud实现抖音的推荐系统
本文基于Spring Cloud实现了一个简化的抖音推荐系统,涵盖用户行为管理、视频资源管理、个性化推荐和实时数据处理四大核心功能。通过Eureka进行服务注册与发现,使用Feign实现服务间调用,并借助Redis缓存用户画像,Kafka传递用户行为数据。文章详细介绍了项目搭建、服务创建及配置过程,包括用户服务、视频服务、推荐服务和数据处理服务的开发步骤。最后,通过业务测试验证了系统的功能,并引入Resilience4j实现服务降级,确保系统在部分服务故障时仍能正常运行。此示例旨在帮助读者理解微服务架构的设计思路与实践方法。
149 17
Spring Cloud Alibaba AI 入门与实践
本文将介绍 Spring Cloud Alibaba AI 的基本概念、主要特性和功能,并演示如何完成一个在线聊天和在线画图的 AI 应用。
550 7
🌱 深入Spring的心脏:Bean配置的艺术与实践 🌟
本文深入探讨了Spring框架中Bean配置的奥秘,从基本概念到XML配置文件的使用,再到静态工厂方式实例化Bean的详细步骤,通过实际代码示例帮助读者更好地理解和应用Spring的Bean配置。希望对你的Spring开发之旅有所助益。
245 4
SpringCloud Alibaba AI整合DeepSeek落地AI项目实战
在现代软件开发领域,微服务架构因其灵活性、可扩展性和模块化特性而受到广泛欢迎。微服务架构通过将大型应用程序拆分为多个小型、独立的服务,每个服务运行在其独立的进程中,服务与服务间通过轻量级通信机制(通常是HTTP API)进行通信。这种架构模式有助于提升系统的可维护性、可扩展性和开发效率。
282 1
Spring Cloud Alibaba与Spring Cloud区别和联系?
Spring Cloud Alibaba与Spring Cloud区别和联系?

热门文章

最新文章

AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等