springcloud3 GateWay章节-Eureka+gateway动态路由负载均衡1

这篇具有很好参考价值的文章主要介绍了springcloud3 GateWay章节-Eureka+gateway动态路由负载均衡1。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

一 GateWay作用以及流程

1.1 GateWay的作用

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

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

1.2 Gateway的组成部分

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

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

1.2.2 断言的一些其他配置

断言就是定义了一组匹配规则,让请求过来后找到对应的router进行处理。这里可以设置时间让其生效,设置cookie,设置请求方式等规则

 1.3 案例说明

例:请求 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     

1.4 Gateway的架构图

gateway根据路由与断言去转发请求到指定的服务。predicate就是我们匹配的条件,fiter是一个无所不能的拦截器,再加上uri,就可以实现 一个具体的路由。

gateway配置路由转发,springcloud3,gateway,spring boot,后端

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

1.5 含gateway的微服务架构图2

gateway配置路由转发,springcloud3,gateway,spring boot,后端

 1.6 微服务常有架构图3

gateway配置路由转发,springcloud3,gateway,spring boot,后端

 

 二 GateWay动态路由案例操作

2.1 案例架构图

默认情况下:gateway会根据注册中心上的微服务名为路径,创建动态路由进行转发,从而实现动态路由的功能。

uri的配置为协议为lb,表示启用gateway的负债均衡功能。如lb://seviceName为spricloud gateway在微服务中自动为我们创建的负债均衡的uri。

gateway配置路由转发,springcloud3,gateway,spring boot,后端

2.2 实际操作

2.2.1 新建一个gateway网关项目

gateway配置路由转发,springcloud3,gateway,spring boot,后端

2.2.2 pom文件的配置

 <!--eureka-client-->
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-actuator</artifactId>
        </dependency>
        <dependency>
            <groupId>org.mybatis.spring.boot</groupId>
            <artifactId>mybatis-spring-boot-starter</artifactId>
        </dependency>
        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>druid-spring-boot-starter</artifactId>
            <version>1.1.10</version>
        </dependency>
        <!--mysql-connector-java-->
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
        </dependency>
        <!--jdbc-->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-jdbc</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-devtools</artifactId>
            <scope>runtime</scope>
            <optional>true</optional>
        </dependency>
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <optional>true</optional>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>
    </dependencies>

2.2.3 路由规则配置文件

方式1: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:硬编码实现方式:了解即可

gateway配置路由转发,springcloud3,gateway,spring boot,后端 2.2.4 项目启动

1.先启动9001,9002 eureka服务;2.再启动9003,9004 提供者;3.启动网关9007;最后查看启动效果图:

gateway配置路由转发,springcloud3,gateway,spring boot,后端

2.查看eureka服务器

gateway配置路由转发,springcloud3,gateway,spring boot,后端

  2.2.5 访问测试

2.2.5.1 情况1测试

1.不使用gateway代理情况下: 直接调用服务

gateway配置路由转发,springcloud3,gateway,spring boot,后端

可以正确访问到

gateway配置路由转发,springcloud3,gateway,spring boot,后端

2.2.5.2  情况2:使用网关路由转发访问

1.请求地址1,实现网关路由转发,并实现负载均衡   本次9004提供服务

gateway配置路由转发,springcloud3,gateway,spring boot,后端

   本次9003提供服务 

gateway配置路由转发,springcloud3,gateway,spring boot,后端

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

 本次9004提供服务

gateway配置路由转发,springcloud3,gateway,spring boot,后端

 本次9003提供服务 

gateway配置路由转发,springcloud3,gateway,spring boot,后端文章来源地址https://www.toymoban.com/news/detail-653260.html

到了这里,关于springcloud3 GateWay章节-Eureka+gateway动态路由负载均衡1的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • springcloud gateway动态路由

    动态每秒调用数据库,加载路由信息到路由定义(RouteDefinition)中 主要是继承  RouteDefinitionRepository接口: 如果项目没有自定义的RouteDefinitionRepository 则会加载InMemoryRouteDefinitionRepository 默认将加载的规则存放在内存,加载application.properties文件中配置的路由规则,InMemory加载内

    2024年02月02日
    浏览(36)
  • springCloud之Gateway动态路由

            学习gateway网关时,是以产品应用为目的,打算做一个类似于SAAS平台,网关负责统一的鉴权,日志记录,对外屏蔽真实的访问地址。路由信息也不能是写死在配置文件的,必须是提供管理页面可维护的。所以就略过配置文件,直接开启动态路由的实现。 一、gateway动态

    2024年02月08日
    浏览(38)
  • SpringCloud nacos 集成 gateway ,实现动态路由

    🎈 作者: Linux猿 🎈 简介: CSDN博客专家🏆,华为云享专家🏆,Linux、C/C++、云计算、物联网、面试、刷题、算法尽管咨询我,关注我,有问题私聊! 🎈 欢迎小伙伴们点赞👍、收藏⭐、留言💬 目录 一、准备工作 1.1 下载代码 1.2 运行代码 二、集成 gateway 2.1 修改 pom.xml 2

    2024年02月16日
    浏览(32)
  • SpringCloud Gateway的使用 + Nacos动态路由

    一、简介 1、什么是gateway? SpringCloud Gateway是spring官方基于Spring 5.0、Spring Boot2.0和Project Reactor等技术开发的网关,旨在为微服务架构提供简单、有效和统一的API路由管理方式 SpringCloud Gateway作为SpringCloud生态系统中的网关,目标是替代Netflix Zuul,在SpringCloud 2.0以上版本中,没有

    2024年02月03日
    浏览(41)
  • SpringCloud-Gateway路由动态配置Nacos实现

    编写配置类 properties添加配置 自定义RouteDefinitionLocator 编写GatewayDynamicConfiguration配置类

    2024年02月07日
    浏览(48)
  • 【SpringCloud-Eureka】Gateway网关

    Gateway概念 特征 核心流程 Eureka服务注册 生产端 Gateway网关 验证网关 路由(Route)是GateWay中最基本的组件之一,表示一个具体的路由信息载体,主要由下面几个部分组成: id:路由唯一标识,区别于其他的route url: 路由指向的目的地URL,客户端请求最终被转发到的微服务 o

    2024年02月05日
    浏览(52)
  • SpringCloud(一)Eureka、Nacos、Feign、Gateway

    微服务,又叫微服务架构,是一种软件架构方式。它将应用构建成一系列按业务领域划分模块的、小的自治服务。 在微服务架构中,每个服务都是自我包含的,并且实现了单一的业务功能。简单来说,就是将一个系统按业务划分成多个子系统,每个子系统都是完整的,可独立

    2024年02月08日
    浏览(39)
  • SpringCloud(五)Gateway 路由网关

    官网地址:https://docs.spring.io/spring-cloud-gateway/docs/current/reference/html/ 我们需要连接互联网,那么就需要将手机或是电脑连接到家里的路由器才可以,而路由器则连接光猫,光猫再通过光纤连接到互联网,也就是说,互联网方向发送过来的数据,需要经过路由器才能到达我们的设

    2024年02月16日
    浏览(43)
  • SpringCloud之 Gateway路由网关

    提示:以下是本篇文章正文内容,SpringCloud 系列学习将会持续更新 官网地址:https://docs.spring.io/spring-cloud-gateway/docs/current/reference/html/ 说到路由,想必各位一定最先想到的就是家里的路由器了,那么我们家里的路由器充当的是一个什么角色呢? 我们知道,如果我们需要连接互

    2024年02月06日
    浏览(46)
  • springcloud微服务架构(eureka、nacos、ribbon、feign、gateway等组件的详细介绍和使用)

    目录 一、微服务演变 1、单体架构(Monolithic Architecture) 2、分布式架构  3、微服务 4、 总结 5、微服务架构 5.1、 微服务技术对比 5.2、企业需求 二、spring cloud  springCloud与SpringBoot的版本兼容关系 1、服务拆分及远程调用 1.1、服务拆分 1.1.1、服务拆分注意事项 1.1.2、项目实战

    2024年02月08日
    浏览(42)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包