摘要:衡量架构伸缩性的主要标准是否容易向集群中添加新的服务器。网站的横向分离将不同业务模块进行分离部署,实现系统伸缩性。大家,可以根据每一种具体的架构设计进行深究。文章借鉴于书籍大型网站技术架构。
网站开发初期,我们习惯性把所有代码都写到一个项目中。
前台、后台、缓存、数据库、静态资源... 等等。
网站系统物理分离
慢慢的系统会原来越大,很显然需要面对大量用户的高并发访问和存储海量数据。
很多用户的请求,不可能在一台服务器上完成。
很多缓存数据,数据库数据,也不可能在一台服务器上完成。
这是,网站的伸缩性架构就变得尤为重要。
如下图。
原理
我们通过多台服务器组装一个整体共同提供服务,通过不断地向集群中加入服务器,来缓解不断上升的
用户并发访问压力和不断增长的数据存储需求。
衡量架构伸缩性的主要标准:
是否容易向集群中添加新的服务器。
当加入新的服务器,是否可以提供和原来的服务器无差别的服务。
集群中可容纳的总的服务器数量是否有限制。
应用服务器集群
只要服务器上不保存数据,所有的服务器都是对等的,通过负载均衡设备就可以向集群中增加服务器。
关系型数据库集群(MYSQL)
关系型数据库的集群伸缩性方案必须在数据库之外实现,通过路由分区等手段将部署有多个数据的服务器组成一个集群。
例如:Mysql 等。
非关系型数据库集群(NOSQL)
非关系型数据库先天就是为海量数据库准备的,因此对伸缩性的支持非常好。
例如:Redis、Memcache 等等。
缓存服务器集群
加入新的服务器可能会导致缓存路由失效,进而导致集群中大部分缓存数据都无法访问。
部署前需要改进缓存路由算法保证缓存数据的可访问性。
静态资源服务器集群
比如 CSS,JS,Img 等资源进行部署到服务器集群,降低流量并提高页面呈现速度。
网站的纵向分离
将业务处理流程上的不同部分进行分离部署,实现系统伸缩性。
如下图。
网站的横向分离
将不同业务模块进行分离部署,实现系统伸缩性。
如下图。
单一功能通过集群规模进行伸缩。
将不同功能分离部署可以实现一定程度的伸缩性,但是随着网站访问量的逐步增加,即使分离到最新粒度的独立部署
单一服务器也不能满足业务规模的要求。
因此,必须使用服务器集群,即将相同服务部署在多台服务器上构成一个集群整体对外服务。
比如:搜索功能。
如果一台服务器可以提供每秒1000次的请求服务,如果网站高峰期,每秒搜索访问量为10000次。
那么,就需要你部署10台服务器构成一个集群。
同理,缓存服务器也会出现这种情况。
事实上,计算一个服务的集群规模,需要同时考虑其对可用性、性能的影响及关联服务集群的影响。
总结
集群伸缩性,可以分为应用服务器集群伸缩性和数据服务器集群伸缩性。
这两种集群由于对数据状态管理的不同,技术实现也有很大的区别。
大家,可以根据每一种具体的架构设计进行深究。
文章借鉴于书籍《大型网站技术架构》。
Thanks ~
AD:
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/21991.html
摘要:使用缓存两个前提条件数据访问热点不均衡数据某时段内有效,不会很快过期反向代理本地缓存分布式缓存异步旨在系统解耦。 大型网站技术架构-入门梳理 标签 : 架构设计 [TOC] 罗列了大型网站架构涉及到的概念,附上了简单说明 前言 本文是对《大型网站架构设计》(李智慧 著)一书的梳理,类似文字版的思维导图 全文主要围绕性能,可用性,伸缩性,扩展性,安全这五个要素 性能,可用性,伸缩性...
摘要:阿里巴巴的共享服务理念以及企业级互联网架构建设的思路,给这些企业带来了不少新的思路,这也是我最终决定写这本书的最主要原因。尽在双阿里巴巴技术演进与超越是迄今唯一由阿里巴巴集团官方出品全面阐述双八年以来在技术和商业上演进和创新历程的书籍。 showImg(https://segmentfault.com/img/remote/1460000015386860); 1、大型网站技术架构:核...
阅读 3277·2023-04-26 00:57
阅读 599·2021-10-08 10:05
阅读 1345·2021-09-08 09:36
阅读 4146·2021-08-12 13:31
阅读 2541·2019-08-30 15:55
阅读 2236·2019-08-30 15:55
阅读 1013·2019-08-30 15:55
阅读 2683·2019-08-29 13:17