当前位置:  开发笔记 > 运维 > 正文

网站架构的伸缩性设计

将不同功能分离部署可以实现一定程度的伸缩性,但是随着网站访问量的逐步增加,即使分离到最新粒度的独立部署单一服务器也不能满足业务规模的要求。因此,必须使用服务器集群,即将相同服务部署在多台服务器上构成一个集群整体对外服务。
网站开发初期,我们习惯性把所有代码都写到一个项目中。

前台、后台、缓存、数据库、静态资源... 等等。

网站系统物理分离

慢慢的系统会原来越大,很显然需要面对大量用户的高并发访问和存储海量数据。

很多用户的请求,不可能在一台服务器上完成。

很多缓存数据,数据库数据,也不可能在一台服务器上完成。

这是,网站的伸缩性架构就变得尤为重要。

如下图。

单一功能通过集群规模进行伸缩。

将不同功能分离部署可以实现一定程度的伸缩性,但是随着网站访问量的逐步增加,即使分离到最新粒度的独立部署单一服务器也不能满足业务规模的要求。

因此,必须使用服务器集群,即将相同服务部署在多台服务器上构成一个集群整体对外服务。

比如:搜索功能。

如果一台服务器可以提供每秒1000次的请求服务,如果网站高峰期,每秒搜索访问量为10000次。

那么,就需要你部署10台服务器构成一个集群。

同理,缓存服务器也会出现这种情况。

事实上,计算一个服务的集群规模,需要同时考虑其对可用性、性能的影响及关联服务集群的影响。

总结

集群伸缩性,可以分为应用服务器集群伸缩性和数据服务器集群伸缩性。

这两种集群由于对数据状态管理的不同,技术实现也有很大的区别。

大家,可以根据每一种具体的架构设计进行深究。

文章借鉴于书籍《大型网站技术架构》。

推荐阅读
殉情放开那只小兔子
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有