当前位置:网站首页>GateWay实现负载均衡
GateWay实现负载均衡
2022-07-31 16:34:00 【m0_67394006】
GateWay实现负载均衡
通过GateWay实现负载均衡的两种方式
自动负载均衡
首先看一下网关服务9999的yml配置:
gateway.discovery.locator.enabled: true #开启自动路由功能
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类似的自动路由规则,具体配置如下:
discovery.locator.enabled: true #这个配置默认为false,但是如果为true,就是开启了通过serviceId转发到具体的服务实例。“localhost:9999/ServiceID/th/**”
在配置好这些以后,我们可以直接通过服务名称来进行访问Nacos中注册的服务和对应的接口
这个位置我们为了测试可以启动2个微服务9001、9002
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";
}
}
测试结果:


手动负载均衡
在以上的配置中,其实是有问题的,问题在于当前的服务名称暴露,并且太过于灵活,那么如果想解决的话,其实可以进行手动配置。
具体配置如下:
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


先自我介绍一下,小编13年上师交大毕业,曾经在小公司待过,去过华为OPPO等大厂,18年进入阿里,直到现在。深知大多数初中级java工程师,想要升技能,往往是需要自己摸索成长或是报班学习,但对于培训机构动则近万元的学费,着实压力不小。自己不成体系的自学效率很低又漫长,而且容易碰到天花板技术停止不前。因此我收集了一份《java开发全套学习资料》送给大家,初衷也很简单,就是希望帮助到想自学又不知道该从何学起的朋友,同时减轻大家的负担。添加下方名片,即可获取全套学习资料哦
边栏推荐
- 牛客 HJ16 购物单
- Qt practical cases (54) - using transparency QPixmap design pictures
- Masterless replication system (2) - read and write quorum
- How to switch remote server in gerrit
- 软件实现AT命令操作过程
- 并发性,时间和相对性
- 智能垃圾桶(八)——红外对管传感器(树莓派pico)
- 多主复制下处理写冲突(3)-收敛至一致的状态及自定义冲突解决逻辑
- 2022年必读的12本机器学习书籍推荐
- MySQL multi-table union query
猜你喜欢

SringMVC中个常见的几个问题

【7.29】Code Source - 【Arrangement】【Stone Game II】【Cow and Snacks】【Minimum Number of Spawns】【Sequence】
![[Meetup Preview] OpenMLDB+OneFlow: Link feature engineering to model training to accelerate machine learning model development](/img/f6/311d5a4c70993df6291250d2025d3f.jpg)
[Meetup Preview] OpenMLDB+OneFlow: Link feature engineering to model training to accelerate machine learning model development

A common method and the use of selenium

组合学笔记(六)局部有限偏序集的关联代数,Möbius反演公式

Dialogue with Zhuang Biaowei: The first lesson of open source

研发过程中的文档管理与工具
How Redis handles concurrent access
![[TypeScript]OOP](/img/d7/b3175ab538906ac1b658a9f361ba44.png)
[TypeScript]OOP

研发过程中的文档管理与工具
随机推荐
TypeError: unhashable type: ‘list‘
Unity 之 图集属性详解和代码示例 -- 拓展一键自动打包图集工具
网站漏洞修复服务商关于越权漏洞分析
Oracle dynamically registers non-1521 ports
ansible study notes 02
Mariabackup implements incremental data backup for Mariadb 10.3
js的toString方法
小程序:matlab解微分方程「建议收藏」
研发过程中的文档管理与工具
Implementing distributed locks based on Redis (SETNX), case: Solving oversold orders under high concurrency
[7.28] Code Source - [Fence Painting] [Appropriate Pairs (Data Enhanced Version)]
Replication Latency Case (3) - Monotonic Read
6. 使用 Postman 工具高效管理和测试 SAP ABAP OData 服务
Applicable Scenarios of Multi-Master Replication (1) - Multi-IDC
Anaconda如何顺利安装CV2
Graham‘s Scan法求解凸包问题
第05章 存储引擎【1.MySQL架构篇】【MySQL高级】
Website vulnerability repair service provider's analysis of unauthorized vulnerability
自动化测试—web自动化—selenium初识
多主复制下处理写冲突(1)-同步与异步冲突检测及避免冲突