微服务之负载均衡

作者: 守候流星雨 | 来源:发表于2018-03-04 15:54 被阅读0次
简介

        在微服务架构中,负载均衡是必须使用的技术,通过它来实现系统的高可用、集群扩容等功能。负载均衡可以分为两种:服务端负载均衡和客户端负载均衡。通常所说的负载均衡指服务器负载均衡,可通过硬件设备或软件来实现,硬件比如:F5、Array等,软件比如:LVS、Nginx等,类似的架构图如下:

图片来自个人微信公众号

        通过硬件或软件实现负载均衡均会维护一个服务端清单,利用心跳检测等手段进行清单维护,保证清单中都是可以正常访问的服务节点。当用户发送请求时,会先到达负载均衡器(也相当于一个服务),负载均衡器根据负载均衡算法(轮训、随机、加权轮训)从可用的服务端列表中取出一台服务端的地址,接着进行转发,降低系统的压力。

        而对于客户端负载均衡来说,与服务端负载均衡的主要区分点在于服务清单的存放位置。在客户端负载均衡中,客户端自己会存储一份服务端清单,它是通过从注册中心(Eureka服务注册中心)进行抓取得到的,同时也需要对此进行维护。

客户端负载均衡(Ribbon)

      SpringCloud Ribbon是基于客户端的负载均衡工具,它可以将面向服务的 REST 模板请求自动转换成客户端负载均衡的服务调用。

图片来自个人微信公众号 图片来自个人微信公众号 图片来自个人微信公众号

        Ribbon 维护了一个服务列表,如果服务实例注销或死掉,Ribbon 能够自行将其剔除。Ribbon 提供了客户端负载均衡的功能,Ribbon利用从 Eureka Server中读取到的服务信息列表(存储在本地即客户端中),在调用服务实例时,合理地进行负载,直接请求到具体的微服务,如下图是Ribbon负载均衡的流程图:

图片来自个人微信公众号
配置步骤

1. 在Eureka客户端开启服务发现(增加EnableDiscoveryClient注解),作用是让客户端可以从服务注册中心获取服务端清单。同时,在定义的RestTemplate对象上使用负载均衡(增加LoadBalanced注解),作用是通过内部机制使之具有负载均衡能力。同时也可设置负载均衡算法等。

图片来自个人微信公众号

2. 使用RestTemplate调用微服务,此时通过服务名进行调用。

图片来自个人微信公众号
其它配置

        可以直接通过配置Ribbon客户端的方式来自定义各个服务客户端调用的参数。

全局配置

  使用ribbon.=的方式设置ribbon的默认参数,如下:

#ribbon请求连接的超时时间

ribbon.ConnectTimeout=250

#请求处理的超时时间

ribbon.ReadTimeout=1000

#对所有操作请求都进行重试

ribbon.OkToRetryOnAllOperations=true

#对当前实例的重试次数

ribbon.MaxAutoRetries=1

#对下个实例的重试次数

ribbon.MaxAutoRetriesNextServer=1

指定服务配置

        使用.ribbon.=的方式进行设置,client表示各个服务客户端,如下:

ly-microservice-clgl.ribbon.ConnectTimeout=500

ly-microservice-clgl.ribbon.ReadTimeout=1000

ly-microservice-clgl.ribbon.NFLoadBalancerRuleClassName=com.netflix.loadbalancer.RandomRule

相关文章

  • 第11章 基本云架构

    11.1 负载分布架构 服务的负载均衡架构 负载均衡的虚拟服务器架构 负载均衡的虚拟交换机架构除了基本负载均衡机制...

  • 负载均衡

    负载均衡图例负载均衡.png 负载均衡策略 轮询 ip_hash 均衡参数 down 表示当前的服务不参与负载均衡...

  • Linux学习笔记-Nginx配置参数详细中文说明

    Nginx多台服务器实现负载均衡: 1.Nginx负载均衡服务器: Nginx负载均衡服务器的nginx.conf...

  • odoo服务器性能调优以及负载均衡

    1 Odoo负载均衡 1.1 Odoo服务器负载均衡 Nginx, odoo服务器做负载均衡,空间换时间 odoo...

  • 负载均衡

    负载均衡可以分为服务端负载均衡和客户端负载均衡,服务端负载均衡完全由服务端负责,客户端不需要做任何事情。客户端负载...

  • Ribbon-负载均衡

    我们的服务都需要部署多实例的,然后实现负载均衡 负载均衡的两种方式 服务器端的负载均衡 客户端侧负载均衡 服务器端...

  • 【深入浅出SpringCloud】I'm Ribbon

    【微服务>>>负载均衡】 一、简介 Ribbon是一个负载均衡组件,具有丰富的负载均衡策略...

  • Spring Cloud之RestTemplate 详解

    什么是客户端负载均衡 我们一般讲的负载均衡都是服务端的负载均衡,比如硬件负载均衡F5,软件负载均衡 Nginx. ...

  • loadBalance 的负载均衡解释

    负载均衡解释?客户端通过负载均衡算法,从服务列表中选择服务地址,进行连接的过程,负载均衡算法有, 轮询、随机、加权...

  • 【Ribbon+Nginx】两者之间有什么区别

    Nginx属于服务端负载均衡,而Ribbon属于本地负载均衡。

网友评论

    本文标题:微服务之负载均衡

    本文链接:https://www.haomeiwen.com/subject/ostqfftx.html