zoukankan      html  css  js  c++  java
  • SpringCloud-Gateway组件使用

    1.什么是服务网关

    1.说明

    • 网关统一服务入口,可方便实现对平台众多服务接口进行管控,对访问服务的身份认证、防报文重放与防数据篡改、功能调用的业务鉴权、响应数据的脱敏、流量与并发控制,甚至基于API调用的计量或者计费等等。

    • 网关 = 路由转发 + 过滤器
      路由转发:接收一切外界请求,转发到后端的微服务上去; 在服务网关中可以完成一系列的横切功能,例如权限校验、限流以及监控等,这些都可以通过过滤器完成

    2.为什么需要网关

    • 1.网关可以实现服务的统一管理
    • 2.网关可以解决微服务中通用代码的冗余问题(如权限控制,流量监控,限流等)

    3.网关组件在微服务中架构

    2.服务网关组件

    1.zuul

    Zuul is the front door for all requests from devices and web sites to the backend of the Netflix streaming application. As an edge service application, Zuul is built to enable dynamic routing, monitoring, resiliency and security.

    1. 原文翻译

      • https://github.com/Netflix/zuul/wiki
      • zul是从设备和网站到Netflix流媒体应用程序后端的所有请求的前门。作为一个边缘服务应用程序,zul被构建为支持动态路由、监视、弹性和安全性。
    2. zuul版本说明

      • 目前zuul组件已经从1.0更新到2.0,但是作为springcloud官方不再推荐使用zuul2.0,但是依然支持zuul2.
    3. springcloud 官方集成zuul文档

    2.gateway

    This project provides a library for building an API Gateway on top of Spring MVC. 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.

    1. 原文翻译

      • https://spring.io/projects/spring-cloud-gateway
      • 这个项目提供了一个在springmvc之上构建API网关的库。springcloudgateway旨在提供一种简单而有效的方法来路由到api,并为api提供横切关注点,比如:安全性、监控/度量和弹性。
    2. 特性

      • 基于springboot2.x 和 spring webFlux 和 Reactor 构建 响应式异步非阻塞IO模型
      • 动态路由
      • 请求过滤

    创建一个新的项目,根据之前写的环境搭建方式

    3.开发网关动态路由

    • 网关配置有两种方式一种是快捷方式,一种是完全展开方式

    1.创建项目引入网关依赖

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

    完整的pom.xml

    <?xml version="1.0" encoding="UTF-8"?>
    <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
             xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
        <modelVersion>4.0.0</modelVersion>
        <parent>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-parent</artifactId>
            <version>2.2.5.RELEASE</version>
            <relativePath/> <!-- lookup parent from repository -->
        </parent>
    
        <groupId>com.md</groupId>
        <artifactId>05-gateway8989</artifactId>
        <version>0.0.1-SNAPSHOT</version>
        <name>05-gateway8989</name>
        <description>Demo project for Spring Boot</description>
    
        <properties>
            <java.version>1.8</java.version>
            <spring-cloud.version>Hoxton.SR6</spring-cloud.version>
        </properties>
    
        <dependencies>
           <!--使用网关的时候web包需要移除掉-->
            <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-starter-web</artifactId>
            </dependency>
    
            <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-starter-test</artifactId>
                <scope>test</scope>
            </dependency>
    
            <!--引入gateway网关依赖-->
            <dependency>
                <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-starter-gateway</artifactId>
            </dependency>
    
            <!--引入consul依赖-->
            <dependency>
                <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-starter-consul-discovery</artifactId>
            </dependency>
    
            <!-- 这个包是用做健康度监控的-->
            <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-starter-actuator</artifactId>
            </dependency>
    
        </dependencies>
    
        <!--全局管理springcloud版本,并不会引入具体依赖-->
        <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>
    
        <build>
            <plugins>
                <plugin>
                    <groupId>org.springframework.boot</groupId>
                    <artifactId>spring-boot-maven-plugin</artifactId>
                </plugin>
            </plugins>
        </build>
    
    </project>
    
    

    快捷方式配置路由

    2.编写网关配置

    spring:
      application:
        name: gateway
      cloud:
        consul:
          host: localhost
          port: 8500
          discovery:
            service-name: ${spring.application.name}
        gateway:
          routes:
            - id: user_route    # 指定路由的唯一标识
              uri: http://localhost:9999/  # 指定路由服务的地址
              predicates:  # 指定路由的规则
                - Path=/user/**
    
            - id: product_route
              uri: http://localhost:9998/
              predicates:
                - Path=/product/**
    
    server:
      port: 8989
    

    3.启动gateway网关项目

    • 直接启动报错:

    • 在启动日志中发现,gateway为了效率使用webflux进行异步非阻塞模型的实现,因此和原来的web包冲突,去掉原来的web即可

    • 再次启动成功启动

    4.测试网关路由转发

    使用之前写的写的,可以看前面几篇文章

    java方式配置路由(了解)

    环境还是和上面的一样

    @Configuration
    public class GatewayConfig {
        @Bean
        public RouteLocator customRouteLocator(RouteLocatorBuilder builder) {
            return builder.routes()
                    .route("order_route", r -> r.path("/order/**")
                            .uri("http://localhost:9997/"))
                    .build();
        }
    }
    

    4.查看网关路由规则列表

    1.说明

    • gateway提供路由访问规则列表的web界面,但是默认是关闭的,如果想要查看服务路由规则可以在配置文件中开启
    management:
      endpoints:
        web:
          exposure:
            include: "*"   #开启所有web端点暴露
    

    访问路由管理列表地址

    3.配置路由服务负载均衡

    1.说明

    • 现有路由配置方式,都是基于服务地址写死的路由转发,能不能根据服务名称进行路由转发同时实现负载均衡的呢?

    2.动态路由以及负载均衡转发配置

    spring:
      application:
        name: gateway
      cloud:
        consul:
          host: localhost
          port: 8500
          discovery:
            service-name: ${spring.application.name}
        gateway:
          routes:
            - id: user_route    # 指定路由的唯一标识
    #          uri: http://localhost:9999/  # 指定路由服务的地址
    
              # lb代表转发后台服务使用负载均衡,users代表服务注册中心上的服务名
              uri: lb://users
              predicates:  # 指定路由的规则
                - Path=/user/**
    
            - id: product_route
    #          uri: http://localhost:9998/
    
              # lb代表负载均衡转发路由,products代表服务注册中心上的服务名
              uri: lb://products
              predicates:
                - Path=/product/**
    
          # 开启根据服务名动态获取路由地址
          discovery:
            locator:
              enabled: true
    
    server:
      port: 8989
    
    #开启所有web端点暴露
    management:
      endpoints:
        web:
          exposure:
            include: "*"
    

    此时访问就实现了负载均衡的效果

    4.常用路由predicate(断言,验证)

    1.Gateway支持多种方式的predicate

    After、Before、Between用于商城活动的时候指定日期才能访问

    2.使用predicate

    spring:
      application:
        name: gateway
      cloud:
        consul:
          host: localhost
          port: 8500
        gateway:
          routes:
            - id: user_route
              #uri: http://localhost:9999/
              uri: lb://users
              predicates:
                - Path=/user/**
                - After=2020-12-21T11:39:33.993+08:00[Asia/Shanghai]
                - Cookie=username,[A-Za-z0-9]+
                - Header=X-Request-Id, d+
    

    5.常用的Filter以及自定义filter

    1.作用

    • 当我们有很多个服务时,比如下图中的user-service、order-service、product-service等服务,客户端请求各个服务的Api时,每个服务都需要做相同的事情,比如鉴权、限流、日志输出等。


    2.使用内置过滤器

    spring:
      application:
        name: gateway
      cloud:
        gateway:
          routes:
            - id: product_route
              #uri: http://localhost:9998/
              uri: lb://products     # lb: 使用负载均衡策略   products代表注册中心的具体服务名
              predicates:
                - Path=/product/**
                #- After=2020-07-30T09:45:49.078+08:00[Asia/Shanghai]
              filters:
              # 为每个请求添加参数id=12
                - AddRequestParameter=id,12
              # 增加响应头  
                - AddResponseHeader=username,chenyn
    

    3.使用自定义filter

    @Configuration
    @Slf4j
    public class CustomGlobalFilter implements GlobalFilter, Ordered {
        @Override
        public Mono<Void> filter(ServerWebExchange exchange, GatewayFilterChain chain) {
            log.info("进入自定义的filter");
            if(exchange.getRequest().getQueryParams().get("username")!=null){
                log.info("用户身份信息合法,放行请求继续执行!!!");
                return chain.filter(exchange);
            }
            log.info("非法用户,拒绝访问!!!");
           return exchange.getResponse().setComplete();
        }
    
        @Override
        public int getOrder() {  //filter 数字越小filter越先执行
            return -1;           //-1  最先执行
        }
    }
    

    自定义全局filter


    作者:山丘!

    -------------------------------------------

    你闻讯而来,我大喜过望,我在这等你,你又在哪呢?喜欢的话加一个“关注”呗!

    如果觉得这篇文章对你有小小的帮助的话,记得在右下角点个“推荐”哦,博主在此感谢!

  • 相关阅读:
    遍历Map集合:java.util.Map.Entry、KeySet两种方式
    Tomcat学习笔记(二)—— 一个简单的Servlet容器
    Tomcat学习笔记(一)一个简单的Web服务器
    对检查性异常和非检查性异常的理解
    org.apache.commons.beanutils.BeanMap简单使用例子
    (转)Java对象克隆(Clone)及Cloneable接口、Serializable接口的深入探讨
    试简述湿式报警阀调试时应满足的要求
    消防水系泵验收时应满足哪些要求
    消防水泵接合器的检查方法和技术要求如下: (1)查看水泵接合器的外观是否有瑕疵,油漆是否完整,形状尺寸和安装尺寸与提供的安装图纸是否相符; (2)对照设计文件查看选择的水泵接合器的型号、名称是否准确、一致; (3)水泵接合器的设置条件是否具备,其设置位置是否是在室外便于消防车接近和使用的地点; (4)检查水泵接合器的外形与室外消火栓是否雷同,以免混淆而延误灭火; (5)检查消防供水设施 官网及阀门
    消防给水和消火栓系统(一)
  • 原文地址:https://www.cnblogs.com/mengd/p/14141223.html
Copyright © 2011-2022 走看看