转自:https://blog.csdn.net/qinglianchen0851/article/details/84306448

仅做个人备份,浏览请看原文

目录

关于负载均衡

常见互联网slb方案

第一层:客户端到反向代理层

第二层:反向代理层到站点层

第三层:站点层到服务层

第四层:访问数据层

数据的均衡

请求的均衡

range水平切分

id哈希水平切分

总结


关于负载均衡

关于负载均衡,其实在网上有许多的定义。而作为云计算的从业者,最经常接触到的就是云负载均衡SLB,我总结了两个特点和作用:分流和灾备。负载均衡(Load Balance)是分布式系统架构设计中必须考虑的因素之一,它通常是指,将请求/数据均匀分摊到多个操作单元上执行,负载均衡的关键在于 分发 !各种负载均衡的算法,也都是为了满足这个分发二字。

常见互联网slb方案

根据上图,可以分为:

  • 客户端层
  • 反向代理层
  • 站点层
  • 服务层
  • 数据层

根据请求的自顶向下,每一层上游请求可以调用多个下游服务。根据负载均衡的调度算法,将请求分发给下层的服务。

第一层:客户端到反向代理层

客户端 -> 反向代理层的负载均衡。这里主要是通过 ”DNS轮询“实现。

通俗来讲,即DNS-server对于一个域名设置多个解析IP(这里指负载均衡的IP),这里的主要的算法是利用了”轮询算法。

第二层:反向代理层到站点层

反向代理,即将客户端的请求转发到服务器上,然后服务器返回的结果转发给客户端。
反向代理层到站点层的负载均衡主要是通过”nginx“本身实现(七层转发),nginx是泛指反向代理,但是也是应用最广泛的反向代理服务器。

而转发的规则(算法),主要是通过修改nginx.conf的配置文件实现:
这里介绍主要几种算法:

  • 请求轮询
  • 最少连接数
  • 加权

【画外音】站点层可以存储session,但强烈不建议这么做,站点层无状态是分布式架构设计的基本原则之一,session最好放到数据层存储。

第三层:站点层到服务层

服务层也叫中间层,通过增加抽象,解耦两个交互的逻辑关系。服务层只提供有限的通用接口,理论上服务集群能够提供无限性能,性能出现瓶颈,服务层一处集中优化

站点层到服务层的负载均衡,是通过“服务连接池”实现的。
上游连接池会建立与下游服务多个连接,每次请求会“随机”选取连接来访问下游服务。除了负载均衡,服务连接池还能够实现***故障转移、超时处理、限流限速、ID串行化***等诸多功能。

第四层:访问数据层

在数据量很大的情况下,由于数据层(db/cache)涉及数据的水平切分,所以数据层的负载均衡更为复杂一些,它分为“数据的均衡”,与“请求的均衡”。

数据的均衡

数据的均衡是指:水平切分后的每个服务(db/cache),数据量是均匀的。

请求的均衡

请求的均衡是指:水平切分后的每个服务(db/cache),请求量是均匀的。

同时,根据水平切分的方式,主要又分为range水平切分和ID哈希水平切分。

range水平切分

每一个数据服务,存储一定范围的数据:

  • user0服务:存储uid范围1-1kw
  • user1服务:存储uid范围1kw-2kw

优点:

规则简单,service只需判断一下uid范围就能路由到对应的存储服务
数据均衡性较好
比较容易扩展,可以随时加一个uid[2kw,3kw]的数据服务

不足:

请求的负载不一定均衡,一般来说,新注册的用户会比老用户更活跃,大range的服务请求压力会更大

id哈希水平切分

每一个数据服务,存储某个key值hash后的部分数据:
user0服务:存储偶数uid数据
user1服务:存储奇数uid数据

优点:

规则简单,service只需对uid进行hash能路由到对应的存储服务
数据均衡性较好
请求均匀性较好

不足:

不容易扩展,扩展一个数据服务,hash方法改变时候,可能需要进行数据迁移

总结

负载均衡(Load Balance)是分布式系统架构设计中必须考虑的因素之一,它通常是指,将请求/数据均匀分摊到多个操作单元上执行,其的关键在于均匀:

  • 反向代理层的负载均衡,是通过“DNS轮询”实现的
  • 站点层的负载均衡,是通过“nginx”实现的
  • 服务层的负载均衡,是通过“服务连接池”实现的
  • 数据层的负载均衡,要考虑“数据的均衡”与“请求的均衡”两个点,常见的方式有“按照范围水平切分”与“hash水平切分”

常见互联网slb方案相关推荐

  1. 互联网推广方案:如何提高企业网站排名!

    对于企业营销人员而言,每天都会在制定互联网推广方案,毫无疑问,SEO优化是每个企业都会尝试的一种推广渠道,它有利于企业在长期的营销推广中,降低营销成本,获取可持续的流量来源. 那么,如何制定网络推广方 ...

  2. 平面设计常见的配色方案及色标

    平面设计常见的配色方案及色标 平面设计常见的配色方案及色标(二) 基本配色--浪漫 ---------------------------------------------------------- ...

  3. 广东省人民政府关于印发广东省深化“互联网+先进制造业”发展工业互联网实施方案及配套政策措施的通知

    2018年3月22日,广东省人民政府印发<广东省支持企业"上云上平台"加快发展工业互联网的若干扶持政策(2018-2020年)>通知. 广东作为制造业大省,大力贯彻实施 ...

  4. 网络分流器|网络分流器|移动互联网采集方案

    网络分流器之戎腾网络移动互联网采集方案!通常我们将网络分为固网和移动互联网二大类! 与传统互联网相比,移动互联网存在两个显著的特性:移动性.控制与承载的分离.移动性要求电信运营商为用户提供随时随地接入 ...

  5. 创业公司 互联网架构方案 整体技术栈 基础设施 数据库 服务治理 消息中间件 日志系统 ELK 自动化部署

    欢迎关注博主公众号:[矿洞程序员]文章由陈晓阳原创. 本人微信:chenxiaoyangzxy. 免费提供本人大量学习资料. 从零开始搭建创业公司后台技术栈 原创: 潘锦 说到后台技术栈,脑海中是不是 ...

  6. 常见流媒体服务器方案对比分析

    目录 前言 正文 SRS 使用步骤 主要功能 EasyDarwin 使用步骤 主要功能 ZLMediaKit 使用步骤 主要功能 Monibuca 使用步骤 主要功能 结尾 对比图表 前言 目前市面上 ...

  7. 分享10个常见互联网词汇!!!

    1.B2B(Business to Business) B2B是指进行电子商务交易的供需双方都是商家(或企业.公司),她们使用了 Internet的技术或各种商务网络平台,完成商务交易的过程.这些过程 ...

  8. php 服务器方案,分享几种常见WEB服务器配置方案

    在众多专用服务器中,WEB服务器应该是我们最为熟知和常用到的了,根据不同的建站及WEB需求,WEB服务器有着好几种常见的环境配置方案,这里就总结分享一下: 当前比较流行的配置就是跑php一般就是,ph ...

  9. 深度点评五种常见WiFi搭建方案

    总结十年无线搭建经验,针对企业常见的五种办公室无线网络方案做个简要分析,各种方案有何优劣,又适用于那种类型的企业. 方案一:仅路由器或AP覆盖 简述:使用路由器或AP覆盖多个无线盲区,多个AP的部署实 ...

最新文章

  1. NFV — 系统架构
  2. 比尔盖茨的十句话,让你改变一生
  3. JDK/Java 17 可能带来什么新特性?
  4. Codeforces Round #654 (Div. 2)
  5. [再寄小读者之数学篇](2014-05-23 递增函数的右极限)
  6. spark算子_Spark算子总结
  7. Banana PI 开源硬件项目启动
  8. 11.ar, nm, objdump
  9. MS CRM 2011 Q2的一些更新
  10. Atitit 读取数据库的api orm SQL Builder sql对比 目录 1.1. 提高生产效率的 ORM 和 SQL Builder 1 1.2. SQL Builder 在 SQL
  11. JavaScript简单计算器
  12. centos 常用的网络登录端口测试工具
  13. 漫画 | 前端发展史的江湖恩怨情仇~
  14. 过去分词和现在分词作非谓语
  15. 【php】PHP制作QQ微信支付宝三合一收款码
  16. 颜宁发微博“求救” 要投拆造谣公众号
  17. 自制p站小姐姐图片返回api.
  18. 用 GitHub 搭建静态博客太繁琐?用这个小工具实现「傻瓜式」发布!
  19. 目前人生阶段的关键字
  20. OpenERP开发文档 2.1.模块开发

热门文章

  1. 【电脑问题解决】戴尔游匣7559 16年 顶配 4k触摸屏 960m显卡 4k屏幕分辨率下使用卡顿(非使用4K分辨率进行游戏)
  2. 数据团队需要的六类角色
  3. Linux宝塔控制面板如何实现多个二级域名301重定向跳转
  4. ArcGIS教程:地理处理服务示例(裁剪与发送)(一)
  5. azure databricks 时区设置
  6. 【Python】星号与双星号
  7. python 有没有 hold on的用法
  8. 爬虫六、gevent协程与queue模块
  9. [Swift]LeetCode414. 第三大的数 | Third Maximum Number
  10. 多久变形金刚2拍摄电影