Spring Cloud全解析:网关之GateWay简介

GateWay简介

由于zuul升级为zuul2时,netflix公司内部出现了分歧,所以springcloud自己研发了一套网关gateway,提供一种简单有效的方式来对API进行路由,以及提供一些强大的过滤器功能,如:熔断、限流、重试等,基于WebFlux框架实现的,底层使用了高性能的Reactor模式通信框架Netty

特性

  • 基于spring5和springboot2构建
  • 动态路由:能够匹配任何请求属性
  • 可以对路由指定断言和过滤器
  • 集成Hystrix断路器功能
  • 集成springcloud服务发现功能
  • 请求限流
  • 支持路径重写

GateWay内部

路由Route

路由是构建网关的基本模块,由ID、目标URI,一系列的断言和过滤器组成,如果断言为true则匹配该路由

断言Predicate

开发人员可以匹配HTTP请求中的所有内容,包括请求头和请求参数,如果请求与断言相匹配,则进行路由

过滤Filter

使用过滤器可以在请求被路由前或后进行过滤

依赖

xml 复制代码
<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-gateway</artifactId>
</dependency>

主启动类

java 复制代码
@SpringBootApplication
@EnableEurekaClient
public class GatewayApp {
    public static void main(String[] args) {
        SpringApplication.run(GatewayApp.class,args);
    }
}

配置

静态路由,给出确切的路由地址进行匹配

yml 复制代码
spring:
  application:
    name: springcloud2-gateway
  cloud:
    gateway:  #gateway网关配置
      routes:
        - id: springcloud2-provider-route  #路由id,唯一
          uri: http://localhost:8001  #匹配后进行访问的路由地址
          predicates:    # 断言,路径进行匹配才会进行路由
            - Path=/dept/**

动态路由,根据微服务名称进行匹配

yml 复制代码
spring:
  application:
    name: springcloud2-gateway
  cloud:
    gateway:  #gateway网关配置
      routes:
        - id: springcloud2-provider-route  #路由id,唯一
#          uri: http://localhost:8001  #匹配后进行访问的路由地址,直接指定访问地址
          uri: lb://springcloud2-provider  #使用负载均衡,根据微服务名称进行负载
          predicates:    # 断言,路径进行匹配才会进行路由
            - Path=/dept/**
      discovery:
        locator:
          enabled: true  #开启从注册中心动态创建路由的功能,利用微服务名称进行路由
# eureka 配置
eureka:
  client:   # 注册到eureka server注册中心
    service-url:
      defaultZone: http://localhost:7001/eureka  # eureka server提供的注册地址
  instance:
    instance-id: springcloud2-gateway  # 服务实例名称,在eureka server页面中的status列中
    prefer-ip-address: true  # 访问路径显示ip

https://zhhll.icu/2021/框架/微服务/springcloud/网关/GateWay/1.GateWay简介/

相关推荐
七星静香11 分钟前
laravel chunkById 分块查询 使用时的问题
java·前端·laravel
Jacob程序员11 分钟前
java导出word文件(手绘)
java·开发语言·word
ZHOUPUYU12 分钟前
IntelliJ IDEA超详细下载安装教程(附安装包)
java·ide·intellij-idea
stewie615 分钟前
在IDEA中使用Git
java·git
Elaine20239130 分钟前
06 网络编程基础
java·网络
G丶AEOM32 分钟前
分布式——BASE理论
java·分布式·八股
落落鱼201333 分钟前
tp接口 入口文件 500 错误原因
java·开发语言
想要打 Acm 的小周同学呀34 分钟前
LRU缓存算法
java·算法·缓存
镰刀出海37 分钟前
Recyclerview缓存原理
java·开发语言·缓存·recyclerview·android面试
阿伟*rui3 小时前
配置管理,雪崩问题分析,sentinel的使用
java·spring boot·sentinel