二.LoadBalancer负载均衡服务调用(1)

1.spring-cloud-loadbalancer概述

(1)官网

2.客户端负载VS服务器端负载

loadbalancer本地负载均衡客户端VSNginx服务端负载均衡区别

Nginx是服务器端负载均衡,客户端所有请求都会交给nignx,然后由nginx实现转发请求,即负载均衡是由服务端实现的

loadbalancer本地负载均衡,在调用微服务端口的时候,会在注册中心上获取注册信息服务列表之后缓存到JVM本地,从而在本地实现RPC远程服务调用技术

3.loadbalancer负载均衡解析

(1)负载均衡理论

2.实操

注册服务

订单80模块修改pom

订单80模块修改controller

@GetMapping(value = "/consumer/pay/get/info" )

private String getInfoByConsul()

{

return restTemplate .getForObject(PaymentSrv_URL + "/pay/get/info" , String.class );

}

测试:交替访问

|---|
| |

(3)总结

负载均衡算法:rest接口第几次请求数 % 服务器集群总数量 = 实际调用服务器位置下标 ,每次服务重启动后rest接口计数从1开始。

List<ServiceInstance> instances = discoveryClient.getInstances("cloud-payment-service");

如: List [0] instances = 127.0.0.1:8002

List [1] instances = 127.0.0.1:8001

8001+ 8002 组合成为集群,它们共计2台机器,集群总数为2, 按照轮询算法原理:

当总请求数为1时: 1 % 2 =1 对应下标位置为1 ,则获得服务地址为127.0.0.1:8001

当总请求数位2时: 2 % 2 =0 对应下标位置为0 ,则获得服务地址为127.0.0.1:8002

当总请求数位3时: 3 % 2 =1 对应下标位置为1 ,则获得服务地址为127.0.0.1:8001

当总请求数位4时: 4 % 2 =0 对应下标位置为0 ,则获得服务地址为127.0.0.1:8002

如此类推......

3.负载均衡算法原理

(1)默认算法

轮询和随机

(2)算法切换

@Configuration
@LoadBalancerClient(
//下面的value值大小写一定要和consul**里面的名字一样,必须一样value = "cloud-payment-service" ,configuration = RestTemplateConfig.class)
public classRestTemplateConfig
{
@Bean
@LoadBalanced //使用@LoadBalanced注解赋予RestTemplate**负载均衡的能力
publicRestTemplate restTemplate(){
return newRestTemplate();
}

@Bean
ReactorLoadBalancer<ServiceInstance> randomLoadBalancer(Environment environment,
LoadBalancerClientFactory loadBalancerClientFactory) {
String name = environment.getProperty(LoadBalancerClientFactory.PROPERTY_NAME);

return newRandomLoadBalancer(loadBalancerClientFactory.getLazyProvider(name, ServiceInstanceListSupplier.class), name);
}
}

相关推荐
sun00770015 分钟前
ubuntu增加swap交换空间
linux·运维·服务器
苹果醋342 分钟前
前端面试之九阴真经
java·运维·spring boot·mysql·nginx
疯狂吧小飞牛1 小时前
openssl颁发包含主题替代名的证书–SAN
运维·服务器·网络
qhd吴飞1 小时前
在linux下用二进制方式安装mysql8
linux·运维·服务器
刘登辉2 小时前
雷电模拟器charles代理抓包
运维·服务器
抽象文学带师2 小时前
配置ssh免密登陆
运维·服务器·ssh
北'辰2 小时前
使用ENSP实现DHCP
运维·网络
.生产的驴3 小时前
Docker Seata分布式事务保护搭建 DB数据源版搭建 结合Nacos服务注册
数据库·分布式·后端·spring cloud·docker·容器·负载均衡
罔闻_spider4 小时前
cookie反爬----普通服务器,阿里系
运维·服务器