springcloud3 GateWay

一 GateWay作用以及流程

1.1 GateWay的作用

gateway相当于所有服务的门户,将客户端请求与服务端应用相分离,客户端请求通过gateway后由定义的路由和断言进行转发,路由代表需要转发请求的地址,断言相当于请求这些地址时所满足的条件,只有同时符合路由和断言才给予转发

gateWay是微服务的API网关,能够实现服务的路由,过滤,断言,流量控制,日志监控等操作。是zuul1.0的升级版。Gateway是基于异步非阻塞开发的。

网关的3大核心组件功能。

1.id 属性,ID 编号,唯一。
2.断言predicates 请求通过 predicates, 判断是否匹配,就是我们匹配的条件
3.filters 属性,可以在请求被路由前或者之后对请求进行修改。
uri 属性,路由重定向的 URI,将请求转发到制定的服务上。 。
order 属性,顺序。当请求匹配到多个路由时,使用顺序小的。

例:请求 http://localhost:6001/tool/test/get 会转发到tool-service-ly服务的test/get接口

即: http://localhost:6001/tool/test/get  =====》  http://tool-service-ly/test/get

spring:
 cloud:
  gateway:
     routes:
        #唯一识别号 ,例:请求 http://localhost:6001/tool/test/get 会转发到tool-service-ly服务的test/get 接口
        - id: TOOL-SERVICE-ly 
          #在服务注册中心找服务名为 tool-service-ly的服务
          uri: lb://tool-service-ly 
           #设置路由断言,代理servicerId为TOOL-SERVICE-ly的   /tool/* 路径
          predicates:
            - Path=/tool/**    
          #前缀, 在当前路径匹配中表示去掉第一个前缀 /tool 即请求从/tool/test/get 变成 /test/get
          filters:
            - StripPrefix=1     

gateway根据路由与断言去转发请求到指定的服务。

predicate就是我们匹配的条件,fiter是一个无所不能的拦截器,再加上uri,就可以实现 一个具体的路由。

springcloud3 GateWay_第1张图片

Springcloud之网关gateway_gateway的作用_java满杯百香果的博客-CSDN博客

1.2 架构图

springcloud3 GateWay_第2张图片

 1.3 微服务常有架构图

springcloud3 GateWay_第3张图片

 二 GateWay的案例操作

2.1 案例架构图

2.2 实际操作

2.2.1 网关项目搭建

1.新建一个网关项目

springcloud3 GateWay_第4张图片

 2.pom文件

 
        
            org.springframework.cloud
            spring-cloud-starter-netflix-eureka-client
        
        
            org.springframework.boot
            spring-boot-starter-web
        
        
            org.springframework.boot
            spring-boot-starter-actuator
        
        
            org.mybatis.spring.boot
            mybatis-spring-boot-starter
        
        
            com.alibaba
            druid-spring-boot-starter
            1.1.10
        
        
        
            mysql
            mysql-connector-java
        
        
        
            org.springframework.boot
            spring-boot-starter-jdbc
        
        
            org.springframework.boot
            spring-boot-devtools
            runtime
            true
        
        
            org.projectlombok
            lombok
            true
        
        
            org.springframework.boot
            spring-boot-starter-test
            test
        
    

3.关键yml的配置

server:
  port: 9007

spring:
  application:
    name: mscloud-cluster-gateway9007
  cloud:
    gateway:
      discovery:
        locator:
          enabled: true #开启从注册中心动态创建路由的功能,利用微服务名进行路由
      routes:
        - id: payment_routh #payment_route    #路由的ID,没有固定规则但要求唯一,建议配合服务名
          #uri: http://localhost:8001          #匹配后提供服务的路由地址
          uri: lb://mscloud-cluster-providers #匹配后提供服务的路由地址
          predicates:
            - Path=/payment/get/**         # 断言,路径相匹配的进行路由

        - id: payment_routh2 #payment_route    #路由的ID,没有固定规则但要求唯一,建议配合服务名
          #uri: http://localhost:8001          #匹配后提供服务的路由地址
          uri: lb://mscloud-cluster-providers #匹配后提供服务的路由地址
          predicates:
            - Path=/payment/lb/**         # 断言,路径相匹配的进行路由
            #- After=2020-02-21T15:51:37.485+08:00[Asia/Shanghai]
            #- Cookie=username,zzyy
            #- Header=X-Request-Id, \d+  # 请求头要有X-Request-Id属性并且值为整数的正则表达式
eureka:
  client:
    #表示是否将自己注册进EurekaServer默认为true。
    register-with-eureka: true
    #是否从EurekaServer抓取已有的注册信息,默认为true。单节点无所谓,集群必须设置为true才能配合ribbon使用负载均衡
    fetchRegistry: true
    service-url:
      #单机版
      #defaultZone: http://localhost:8003/eureka/
      # 集群版
      defaultZone: http://mscloud-euk1:9001/eureka/,http://mscloud-euk2:9002/eureka/
  instance:
    instance-id: gateway9007
    #访问路径可以显示IP地址
    prefer-ip-address: true
    #Eureka客户端向服务端发送心跳的时间间隔,单位为秒(默认是30秒)
    #lease-renewal-interval-in-seconds: 1
    #Eureka服务端在收到最后一次心跳后等待时间上限,单位为秒(默认是90秒),超时将剔除服务
    #lease-expiration-duration-in-seconds: 2

2.2.2 项目测试

1.先启动9001,9002 eureka服务

2.再启动9003,9004 提供者

3.启动网关9007

springcloud3 GateWay_第5张图片

1.直接调用服务

springcloud3 GateWay_第6张图片

2.使用网关路由转发访问

1.请求地址1,实现网关路由转发,并实现负载均衡

2.请求地址2,实现网关路由转发,多刷新几次,出现负载均衡效果

springcloud3 GateWay_第7张图片

你可能感兴趣的:(springcloud3,gateway,spring,boot,后端)