spring cloud gateway实践

本文涉及的产品
网络型负载均衡 NLB,每月750个小时 15LCU
应用型负载均衡 ALB,每月750个小时 15LCU
传统型负载均衡 CLB,每月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>

       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();
	}
}

    (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

    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);
    }
}

    (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

    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

    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;
    }

    

  

相关实践学习
SLB负载均衡实践
本场景通过使用阿里云负载均衡 SLB 以及对负载均衡 SLB 后端服务器 ECS 的权重进行修改,快速解决服务器响应速度慢的问题
负载均衡入门与产品使用指南
负载均衡(Server Load Balancer)是对多台云服务器进行流量分发的负载均衡服务,可以通过流量分发扩展应用系统对外的服务能力,通过消除单点故障提升应用系统的可用性。 本课程主要介绍负载均衡的相关技术以及阿里云负载均衡产品的使用方法。
目录
相关文章
|
16天前
|
JSON Java API
利用Spring Cloud Gateway Predicate优化微服务路由策略
Spring Cloud Gateway 的路由配置中,`predicates`​(断言)用于定义哪些请求应该匹配特定的路由规则。 断言是Gateway在进行路由时,根据具体的请求信息如请求路径、请求方法、请求参数等进行匹配的规则。当一个请求的信息符合断言设置的条件时,Gateway就会将该请求路由到对应的服务上。
120 69
利用Spring Cloud Gateway Predicate优化微服务路由策略
|
4天前
|
人工智能 自然语言处理 Java
Spring Cloud Alibaba AI 入门与实践
本文将介绍 Spring Cloud Alibaba AI 的基本概念、主要特性和功能,并演示如何完成一个在线聊天和在线画图的 AI 应用。
92 7
|
23天前
|
XML Java 数据格式
🌱 深入Spring的心脏:Bean配置的艺术与实践 🌟
本文深入探讨了Spring框架中Bean配置的奥秘,从基本概念到XML配置文件的使用,再到静态工厂方式实例化Bean的详细步骤,通过实际代码示例帮助读者更好地理解和应用Spring的Bean配置。希望对你的Spring开发之旅有所助益。
88 3
|
1月前
|
XML Java 数据格式
Spring Core核心类库的功能与应用实践分析
【12月更文挑战第1天】大家好,今天我们来聊聊Spring Core这个强大的核心类库。Spring Core作为Spring框架的基础,提供了控制反转(IOC)和依赖注入(DI)等核心功能,以及企业级功能,如JNDI和定时任务等。通过本文,我们将从概述、功能点、背景、业务点、底层原理等多个方面深入剖析Spring Core,并通过多个Java示例展示其应用实践,同时指出对应实践的优缺点。
57 14
|
1月前
|
缓存 Java 数据库连接
Spring框架中的事件机制:深入理解与实践
Spring框架是一个广泛使用的Java企业级应用框架,提供了依赖注入、面向切面编程(AOP)、事务管理、Web应用程序开发等一系列功能。在Spring框架中,事件机制是一种重要的通信方式,它允许不同组件之间进行松耦合的通信,提高了应用程序的可维护性和可扩展性。本文将深入探讨Spring框架中的事件机制,包括不同类型的事件、底层原理、应用实践以及优缺点。
67 8
|
1月前
|
JavaScript Java Kotlin
深入 Spring Cloud Gateway 过滤器
Spring Cloud Gateway 是新一代微服务网关框架,支持多种过滤器实现。本文详解了 `GlobalFilter`、`GatewayFilter` 和 `AbstractGatewayFilterFactory` 三种过滤器的实现方式及其应用场景,帮助开发者高效利用这些工具进行网关开发。
210 1
|
1月前
|
消息中间件 监控 Java
如何将Spring Boot + RabbitMQ应用程序部署到Pivotal Cloud Foundry (PCF)
如何将Spring Boot + RabbitMQ应用程序部署到Pivotal Cloud Foundry (PCF)
38 6
|
1月前
|
负载均衡 Java 开发者
深入探索Spring Cloud与Spring Boot:构建微服务架构的实践经验
深入探索Spring Cloud与Spring Boot:构建微服务架构的实践经验
149 5
|
1月前
|
XML 前端开发 安全
Spring MVC:深入理解与应用实践
Spring MVC是Spring框架提供的一个用于构建Web应用程序的Model-View-Controller(MVC)实现。它通过分离业务逻辑、数据、显示来组织代码,使得Web应用程序的开发变得更加简洁和高效。本文将从概述、功能点、背景、业务点、底层原理等多个方面深入剖析Spring MVC,并通过多个Java示例展示其应用实践,同时指出对应实践的优缺点。
83 2
|
1月前
|
Java 关系型数据库 MySQL
如何将Spring Boot + MySQL应用程序部署到Pivotal Cloud Foundry (PCF)
如何将Spring Boot + MySQL应用程序部署到Pivotal Cloud Foundry (PCF)
62 5