• 微服务学习第三十二节


    GateWay实现负载均衡

    在之前的学习中,我们已经掌握了GateWay的一些基本配置,包括两种配置方法,但是其中有很多的配置细节,我们没有细讲,包括我们现在的配置是写死的具体端口号,那么这节课,我们要实现通过GateWay实现负载均衡的两种方式

    自动负载均衡

    首先我们看一下我们之前的网关服务9999的yml配置,这里的配置信息,其实有一些,咱们目前是不清楚的,比如:

    1. gateway.discovery.locator.enabled: true #开启自动路由功能
    2. routes中的uri其实最后是不需要服务名称的,这个位置其实只需要指定的localhost:9001即可
    server:
      port: 9999
    spring:
      application:
        name: cloud-gateway-service
      cloud:
        nacos:
          discovery:
            server-addr: localhost:8848
        gateway:
          discovery:
            locator:
              enabled: true #开启自动路由功能,根据服务名称自动创建routes
          routes:  # 路由
            - id: nacos-provider #路由ID,没有固定要求,但是要保证唯一,建议配合服务名
              uri: http://localhost:9001/nacos-provider # 匹配提供服务的路由地址
              predicates: # 断言
                - Path=/msb/** # 断言,路径相匹配进行路由
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18

    所以这个位置我们可以把当前的配置优化为以下情况,它是一样可以启动的,我们可以进行测试启动9001和网关9999,通过网关来访问"localhost:9999/msb/**"

    server:
      port: 9999
    spring:
      application:
        name: cloud-gateway-service
      cloud:
        nacos:
          discovery:
            server-addr: localhost:8848
        gateway:
          routes:  # 路由
            - id: nacos-provider #路由ID,没有固定要求,但是要保证唯一,建议配合服务名
              uri: http://localhost:9001 # 匹配提供服务的路由地址
              predicates: # 断言
                - Path=/msb/** # 断言,路径相匹配进行路由
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15

    GateWay还提供了和Zuul类似的自动路由规则,具体配置如下:

    1. discovery.locator.enabled: true #这个配置默认为false,但是如果为true,就是开启了通过serviceId转发到具体的服务实例。“localhost:9999/ServiceID/msb/**”
    2. 在配置好这些以后,我们可以直接通过服务名称来进行访问Nacos中注册的服务和对应的接口
    3. 这个位置我们为了测试可以启动2个微服务9001、9002
    4. GateWay在开启了自动路由以后,还自带负载均衡
    server:
      port: 9999
    spring:
      application:
        name: cloud-gateway-service
      cloud:
        nacos:
          discovery:
            server-addr: localhost:8848
        gateway:
          discovery:
            locator:
              enabled: true #是否与服务发现组件进行结合,通过serviceId转发到具体的服务实例。默认为false,设为true便开启通过服务中心的自动根据 serviceId 创建路由的功能。
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13

    9002和9001保持一致,Controller保持一致,负载均衡测试

    package com.mashibing.cloudalibabanacos9002.controller;
    
    import org.springframework.beans.factory.annotation.Value;
    import org.springframework.web.bind.annotation.GetMapping;
    import org.springframework.web.bind.annotation.PathVariable;
    import org.springframework.web.bind.annotation.RequestMapping;
    import org.springframework.web.bind.annotation.RestController;
    
    @RestController
    @RequestMapping("/msb")
    public class DemoController {
    
        @Value("${server.port}")
        private String serverPort;
    
        @GetMapping(value = "/get")
        public String getServerPort(){
            return "库存-1:"+serverPort;
        }
    
        @GetMapping(value = "custom")
        public String customTest(){
            return "测试网关配置类~~custom";
        }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25

    测试结果:

    • 访问地址:
      • http://localhost:9999/nacos-provider/msb/get

    在这里插入图片描述

    在这里插入图片描述

    手动负载均衡

    在以上的配置中,其实是有问题的,问题在于当前的服务名称暴露,并且太过于灵活,那么如果想解决的话,其实我们可以进行手动配置。

    具体配置如下:

    server:
      port: 9999
    spring:
      application:
        name: cloud-gateway-service
      cloud:
        nacos:
          discovery:
            server-addr: localhost:8848
        gateway:
          discovery:
            locator:
              enabled: true #开启自动路由功能(此时可以关闭)
          routes: # 路由
            - id: nacos-provider #路由ID,没有固定要求,但是要保证唯一,建议配合服务名
              uri: lb://nacos-provider # 匹配提供服务的路由地址
              predicates: # 断言
                - Path=/msb/** 
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18

    测试

    我们现在开启9001/9002两个服务和9999网关服务,然后此时我们可以通过网关去访问:http://localhost:9999/msb/get

    在这里插入图片描述

    在这里插入图片描述

  • 相关阅读:
    如何使用tornado将python代码封装成api
    .NET MAUI开源架构_2.什么是 .NET MAUI?
    PYTHON第一次
    SQL Server设置定时作业调度Schedule
    Oracle 11g R2 Rman备份与恢复(二)
    树莓派、ubuntu低版本python3安装库
    【今日文章】:Web端常用的Observer监听器
    设计模式:工厂模式
    蓝桥杯练习系统(算法训练)ALGO-980 斐波那契串
    用合成数据训练车辆姿态估计神经网络
  • 原文地址:https://blog.csdn.net/qq_29374433/article/details/125493502