常见互联网slb方案
转自: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方案相关推荐
- 互联网推广方案:如何提高企业网站排名!
对于企业营销人员而言,每天都会在制定互联网推广方案,毫无疑问,SEO优化是每个企业都会尝试的一种推广渠道,它有利于企业在长期的营销推广中,降低营销成本,获取可持续的流量来源. 那么,如何制定网络推广方 ...
- 平面设计常见的配色方案及色标
平面设计常见的配色方案及色标 平面设计常见的配色方案及色标(二) 基本配色--浪漫 ---------------------------------------------------------- ...
- 广东省人民政府关于印发广东省深化“互联网+先进制造业”发展工业互联网实施方案及配套政策措施的通知
2018年3月22日,广东省人民政府印发<广东省支持企业"上云上平台"加快发展工业互联网的若干扶持政策(2018-2020年)>通知. 广东作为制造业大省,大力贯彻实施 ...
- 网络分流器|网络分流器|移动互联网采集方案
网络分流器之戎腾网络移动互联网采集方案!通常我们将网络分为固网和移动互联网二大类! 与传统互联网相比,移动互联网存在两个显著的特性:移动性.控制与承载的分离.移动性要求电信运营商为用户提供随时随地接入 ...
- 创业公司 互联网架构方案 整体技术栈 基础设施 数据库 服务治理 消息中间件 日志系统 ELK 自动化部署
欢迎关注博主公众号:[矿洞程序员]文章由陈晓阳原创. 本人微信:chenxiaoyangzxy. 免费提供本人大量学习资料. 从零开始搭建创业公司后台技术栈 原创: 潘锦 说到后台技术栈,脑海中是不是 ...
- 常见流媒体服务器方案对比分析
目录 前言 正文 SRS 使用步骤 主要功能 EasyDarwin 使用步骤 主要功能 ZLMediaKit 使用步骤 主要功能 Monibuca 使用步骤 主要功能 结尾 对比图表 前言 目前市面上 ...
- 分享10个常见互联网词汇!!!
1.B2B(Business to Business) B2B是指进行电子商务交易的供需双方都是商家(或企业.公司),她们使用了 Internet的技术或各种商务网络平台,完成商务交易的过程.这些过程 ...
- php 服务器方案,分享几种常见WEB服务器配置方案
在众多专用服务器中,WEB服务器应该是我们最为熟知和常用到的了,根据不同的建站及WEB需求,WEB服务器有着好几种常见的环境配置方案,这里就总结分享一下: 当前比较流行的配置就是跑php一般就是,ph ...
- 深度点评五种常见WiFi搭建方案
总结十年无线搭建经验,针对企业常见的五种办公室无线网络方案做个简要分析,各种方案有何优劣,又适用于那种类型的企业. 方案一:仅路由器或AP覆盖 简述:使用路由器或AP覆盖多个无线盲区,多个AP的部署实 ...
最新文章
- NFV — 系统架构
- 比尔盖茨的十句话,让你改变一生
- JDK/Java 17 可能带来什么新特性?
- Codeforces Round #654 (Div. 2)
- [再寄小读者之数学篇](2014-05-23 递增函数的右极限)
- spark算子_Spark算子总结
- Banana PI 开源硬件项目启动
- 11.ar, nm, objdump
- MS CRM 2011 Q2的一些更新
- Atitit 读取数据库的api orm SQL Builder sql对比 目录 1.1. 提高生产效率的 ORM 和 SQL Builder	1 1.2. SQL Builder 在 SQL
- JavaScript简单计算器
- centos 常用的网络登录端口测试工具
- 漫画 | 前端发展史的江湖恩怨情仇~
- 过去分词和现在分词作非谓语
- 【php】PHP制作QQ微信支付宝三合一收款码
- 颜宁发微博“求救” 要投拆造谣公众号
- 自制p站小姐姐图片返回api.
- 用 GitHub 搭建静态博客太繁琐?用这个小工具实现「傻瓜式」发布!
- 目前人生阶段的关键字
- OpenERP开发文档 2.1.模块开发