在这个渐进式的演化过程中,最重要的技术手段就是使用服务器集群,通过不断地向集群中添加服务器来增强整个集群的处理能力。这就是网站系统的伸缩性架构,只要 技术上能做到向集群中加入服务器的数量和集群的处理能力成线性关系,那么网站就可 以以此手段不断提升自己的规模,从一个服务几十人的小网站发展成服务几十亿人的大 网站,从只能存储几个G图片的小网站发展成存储几百P图片的大网站。这个演化过程总体来说是渐进式的,而且总是在“伸”,也就是说,网站的规模和服务器的规模总是在不断扩大(通常,一个需要“缩”的网站可能已经无法经营下去了)。但是这个过程也可能因为运营上的需要而出现脉冲,比如前面案例中提到的电商网站的 促销活动:在某个短时间内,网站的访问量和交易规模突然爆发式增长,然后又回归正 常状态。这时就需要网站的技术架构具有极好的伸缩性一一活动期间向服务器集群中加 入更多服务器(及向网络服务商租借更多的网络带宽)以满足用户访问,活动结束后又 将这些服务器下线以节约成本。
国内有许多传统企业“触网”,将传统业务搬上互联网,这是一件值得称道
的事,传统行业与互联网结合将会创造出新的经济模式,改善人们的生活。但遗 憾的是,有些传统企业将自己的管理模式和经营理念也照搬到互联网领域一一在 技术方面的表现就是一开始就企图打造一个大型网站。
回顾网站架构发展历程,网站架构发展史就是一部不断向网站添加服务器的历史。 只要工程师能向网站的服务器集群中添加新的机器,只要新添加的服务器能线性提高网 站的整体服务处理能力,网站就无需为不断增长的用户和访问而焦虑。
一般说来,网站的伸缩性设计可分成两类,一类是根据功能进行物理分离实现伸缩, 一类是单一功能通过集群实现伸缩。前者是不同的服务器部署不同的服务,提供不同的 功能;后者是集群内的多台服务器部署相同的服务,提供相同的功能。
1 不同功能进行物理分离实现伸缩
网站发展早期——通过增加服务器提高网站处理能力时,新增服务器总是从现有服 务器中分离出部分功能和服务,如图6.1所示。
每次分离都会有更多的服务器加入网站,使用新增的服务器处理某种特定服务。事 实上,通过物理上分离不同的网站功能,实现网站伸缩性的手段,不仅可以用在网站发 展早期,而且可以在网站发展的任何阶段使用。具体又可分成如下两种情况。
纵向分离(分层后分离):将业务处理流程上的不同部分分离部署,实现系统伸缩性,
如图6.2所示。
横向分离(业务分割后分离):将不同的业务模块分离部署,实现系统伸缩性。
横向分离的粒度可以非常小,甚至可以一个关键网页部署一个独立服务,比如对于 电商网站非常重要的产品详情页面,商铺页面,搜索列表页面,每个页面都可以独立部 署,专门维护。
2 单一功能通过集群规模实现伸缩
总目录展示
该笔记共八个节点(由浅入深),分为三大模块。
高性能。 秒杀涉及大量的并发读和并发写,因此支持高并发访问这点非常关键。该笔记将从设计数据的动静分离方案、热点的发现与隔离、请求的削峰与分层过滤、服务端的极致优化这4个方面重点介绍。
一致性。 秒杀中商品减库存的实现方式同样关键。可想而知,有限数量的商品在同一时刻被很多倍的请求同时来减库存,减库存又分为“拍下减库存”“付款减库存”以及预扣等几种,在大并发更新的过程中都要保证数据的准确性,其难度可想而知。因此,将用一个节点来专门讲解如何设计秒杀减库存方案。
高可用。 虽然介绍了很多极致的优化思路,但现实中总难免出现一些我们考虑不到的情况,所以要保证系统的高可用和正确性,还要设计一个PlanB来兜底,以便在最坏情况发生时仍然能够从容应对。笔记的最后,将带你思考可以从哪些环节来设计兜底方案。
篇幅有限,无法一个模块一个模块详细的展示(这些要点都收集在了这份《高并发秒杀顶级教程》里),麻烦各位转发一下(可以帮助更多的人看到哟!)
由于内容太多,这里只截取部分的内容。
78456645)]
[外链图片转存中…(img-Enu5393S-1719478456645)]
由于内容太多,这里只截取部分的内容。