电商商城定制开发springcloud之Ribbon

文章目录

1、基础知识

LB-负载均衡(Load Balance)
电商商城定制开发简单来说就是将用户的电商商城定制开发请求平摊的分配到多个服务上,电商商城定制开发从而达到系统的HA(高可用)。常用的软件有Nginx,LVS等。

什么是Ribbon
是基于Netflix Ribbon实现的一套客户端负载均衡的工具。

Ribbon客户端和Nignx服务端负载均衡的区别

  • Nginx是服务器负载均衡,客户端所有请求都会交给nginx,然后由nginx实现转发请求。即负载均衡是由服务器实现的。
  • Ribbon本地负载均衡,在调用微服务接口时候,会在注册中心上获取注册信息服务列表之后缓存到JVM本地,从而在本地实现RPC远程服务调用技术。

2、集成Ribbon

负载均衡和RestTemplate调用

Ribbon已经集成到EurekaClient中

使用

3、Ribbon自带的负载规则

  • com.netflix.loadbalancer.RoundRobinRule:轮询
  • com.netflix.loadbalancer.RandomRule:随机
  • com.netflix.loadbalancer.RetryRule:先按照轮询,如果获取失败则在指定时间内会进行重试,获取可用的的服务
  • WeightedResponseTimeRule:对轮询的扩展,响应速度越快的实例选择权重越大,越容易被选择
  • BestAvailableRule:会先过滤由于多次访问故障而处于断路器跳闸状态的服务,然后选择一个并发量最小的服务
  • AvailabilityFilteringRule:先过滤掉故障实例,再选择并发较小的实例
  • ZoneAvoidanceRule:默认规则,复合判断server所在区域的性能和server的可用性选择服务器

4、Ribbon负载规则修改

自定义配置类不能放在@ComponentScan所扫描的当前包下以及子包下,否则自定义的这个配置类会被所有的Ribbon客户端共享,不能实现特殊定制的目的。


随机规则类

@Configurationpublic class MySelfRule {    @Bean    public IRule myRule(){        return new RandomRule();//定义为随机    }}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7

启动类加载随机规则

@SpringBootApplication@EnableEurekaClient@RibbonClient(name = "CLOUD-PAYMENT-SERVICE",configuration = MySelfRule.class)public class OrderMain80 {    public static void main(String[] args) {        SpringApplication.run(OrderMain80.class, args);    }}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8

http://localhost/consumer/payment/get/1

多次测试,端口随机出现,证明访问8001和8002服务器随机指定访问。

5、Ribbon负载均衡算法原理

网站建设定制开发 软件系统开发定制 定制软件开发 软件开发定制 定制app开发 app开发定制 app开发定制公司 电商商城定制开发 定制小程序开发 定制开发小程序 客户管理系统开发定制 定制网站 定制开发 crm开发定制 开发公司 小程序开发定制 定制软件 收款定制开发 企业网站定制开发 定制化开发 android系统定制开发 定制小程序开发费用 定制设计 专注app软件定制开发 软件开发定制定制 知名网站建设定制 软件定制开发供应商 应用系统定制开发 软件系统定制开发 企业管理系统定制开发 系统定制开发