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=/th/** # 断言,路径相匹配进行路由

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

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=/th/** # 断言,路径相匹配进行路由

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

  1. discovery.locator.enabled: true #这个配置默认为false,但是如果为true,就是开启了通过serviceId转发到具体的服务实例。“localhost:9999/ServiceID/th/**”

  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 创建路由的功能。

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

package com.tianhao.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("/th")
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";
    }
}

测试结果:

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

GateWay实现负载均衡_第1张图片

GateWay实现负载均衡_第2张图片

手动负载均衡

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

具体配置如下:

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=/th/** 

测试

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

GateWay实现负载均衡_第3张图片GateWay实现负载均衡_第4张图片

最后

深知大多数初中级Java工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则近万的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《Java开发全套学习资料》送给大家,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

小编已加密:aHR0cHM6Ly9kb2NzLnFxLmNvbS9kb2MvRFVrVm9aSGxQZUVsTlkwUnc==出于安全原因,我们把网站通过base64编码了,大家可以通过base64解码把网址获取下来。

你可能感兴趣的:(面试,学习路线,阿里巴巴,gateway,负载均衡,java,jvm,数据结构)