揭秘大型网站架构进化之路

转载 2018年01月03日 00:00:00

互联网上有很多关于网站架构的各种分享,有些主要是从运维和基础架构的角度去分析的(堆机器,做集群),太关注技术细节实现,普通的开发人员基本看不太懂。

本文第一章节将主要介绍大型网站基础架构的扩展,第二章节则重点从应用程序的角度去介绍网站架构的扩展和演变。


一,大型网站基础架构的扩展


草根时期,快速开发网站并上线。当然,通常只是先试水,用户规模也没有形成,经济能力和投入也非常有限。

640?wx_fmt=png&wxfrom=5&wx_lazy=1

有一定的业务量和用户规模了,想提升网站速度,于是,缓存出场了。

0?wx_fmt=png

市场反响还不错,用户量每天在增长,数据库疯狂读写,逐渐发现一台服务器快撑不住了。于是,决定把DB和APP做分离。

0?wx_fmt=jpeg

单台数据库也感觉快撑不住了,一般都会尝试做“读写分离”。由于大部分互联网“读多写少”的特性所决定的。Salve的台数,取决于按业务评估的读写比例。

0?wx_fmt=jpeg


数据库层面是缓解了,但是应用程序层面也出现了瓶颈,由于访问量增大,加上早期程序员水平有限写的代码也很烂,人员流动性也大,很难去维护和优化。所以,很常用的办法还是“堆机器”。

0?wx_fmt=jpeg


加机器谁都会加,关键是加完之后得有效果,加完之后可能会引发一些问题。例如非常常见的:页面输出缓存和本地缓存的问题,Session保存的问题......

0?wx_fmt=png

到这里,已经基本做到了DB层面和应用层面的横向扩展了,可以开始关注一些其它方面,例如:站内搜索的精准度,对DB的依赖,开始引入全文索引。

Java领域用的较多的是Lucene、Solr等,而php领域用的比较多的是sphinx/coreseek。

0?wx_fmt=jpeg

到目前为止,一个能够承载日均百万级访问量的中型网站架构基本介绍完了。


二,从应用程序的角度去看架构扩展


在做扩展满足了基本的性能需求后,我们会逐渐关注“可用性”(也就是我们通常听别人吹牛时说的SLA、几个9)。如何保证真正“高可用”,也是个难题。

0?wx_fmt=jpeg

几乎主流的大中型互联网公司,都会有用到类似的架构,只是节点数不同而已。


还有一招用的比较多的,那就是动静分离。可以需要开发人员配合(把静态资源放独立站点下),也可以不需要开发人员配合(利用7层反向代理来处理,根据后缀名等信息来判断资源类型)。有了单独的静态文件服务器之后,存储也是个问题,也需要扩展。多台服务器的文件怎么保持一致,买不起共享存储怎么办?分布式文件系统也派上用场了。

0?wx_fmt=jpeg

还有一项目前国内外用的非常普遍的技术CDN加速。目前该领域竞争激烈,也已经比较便宜了。国内南北互联网问题比较严重,使用CDN可以有效解决这个问题。

CDN的基本原理并不复杂,可以理解为智能DNS+Squid反向代理缓存 ,然后需要有很多机房节点提供访问。


0?wx_fmt=jpeg

截止目前为止,都没有怎么去改动应用程序的架构,或者说通俗点,都不怎么需要大面积的修改代码。

如果上面那些手段都用光了,还是支撑不住怎么办?不停的加机器也不是办法啊?

随着业务越来越复杂,网站的功能越来越多,虽然部署层面是采用的集群,但是应用程序架构层面还是“集中式”的,这样会导致很多耦合,不便于开发、维护,而且容易“一荣俱损”。所以,通常会把网站拆分出不同的子站点来单独宿主。

0?wx_fmt=png

应用都拆了,由于单个数据库的连接,QPS,TPS,I/O处理能力都非常有限,DB层面也可以去做垂直分库操作

0?wx_fmt=png

拆分应用和DB之后,其实还是会有很多问题。不同的站点,里面可能会有相同逻辑和功能的代码。当然,对于一些基础的功能我们可以封装DLL或者Jar包去到处提供引用,但是这种强依赖也很容易造成一些问题(版本问题、依赖关系等处理起来非常麻烦)。这样,传说中的SOA的价值就得到体现了。

0?wx_fmt=jpeg

应用、服务之间还是会出现一些依赖问题,这时候,高吞吐量的解耦利器出现了


0?wx_fmt=png


最后,还介绍一个大型互联网公司都用的绝技--分库分表。个人经验,不是业务发站和各方面非常迫切,不要轻易走这一步。

因为分库分表谁都会干,关键是拆完之后怎么办。分库分表主要考虑以下几个维度:横向拆分,纵向拆分,分布式数据访问层,数据库中间件(代理)

推荐阅读:

技术:分布式事务架构实践

技术:分布式唯一ID极简教程

分享:2T架构师学习资料干货分享

觉得有帮助?请转发给更多人!

0?wx_fmt=png0?wx_fmt=png

架构师小秘圈,聚集10万架构师的小圈子!不定期分享技术干货,行业秘闻!汇集各类奇妙好玩的话题和流行动向!长按左侧图片,扫码加入架构师微信群!

淘宝的十年技术之路

2014-10-15    分类:程序员人生1人评论     来源:内向爆裂 分享到:更多19 最近有幸,在学校的图书馆借到了子柳先生的《淘宝技术这十年》,拜读一番,感慨万分。...
  • leoking01
  • leoking01
  • 2014-11-12 10:10:16
  • 693

大型网站架构进化阶段

1、 最开始,由于某些想法或者爱好,于是在互联网上搭建了一个网站,这个时候甚至有可能主机都是租借的,但由于我们先关注架构的演变历程,因此就假设这个时候已经是托管了一台主机,并且有一定的带宽了。 初始...
  • JohnShu
  • JohnShu
  • 2017-01-10 10:58:13
  • 519

软件架构之——好的架构是进化来的,不是设计来的

http://kb.cnblogs.com/page/531834/
  • l1028386804
  • l1028386804
  • 2015-11-23 10:47:36
  • 702

淘宝技术架构变迁

一、个人网站    2003 年 4 月 7 日,马云,在杭州,成立了一个神秘的组织。他叫来十位员工,要他们签了一份协议,这份协议要求他们立刻离开阿里巴巴,去做一个神秘的项目。这个项目要求绝对保密,...
  • qq773837256
  • qq773837256
  • 2016-05-16 15:36:43
  • 5296

各大电商系统架构进化之路

https://github.com/aalansehaiyang/technology-talk/blob/master/system-architecture/%E7%BB%8F%E5%85%B8...
  • u013214151
  • u013214151
  • 2017-06-16 14:41:00
  • 213

进化式构建大型网站架构

来源: itivy  发布时间: 2011-05-02   原文链接   [收藏]     之前我简单向大家介绍了各个知名大型网站的架构,MySpace的五个里程碑、Flickr...
  • lanyd
  • lanyd
  • 2015-12-03 15:14:54
  • 245

大型网站架构之路

前言 一个成熟的大型网站(如淘宝、京东等)的系统架构并不是开始设计就具备完整的高性能、高可用、安全等特性,它总是随着用户量的增加,业务功能的扩展逐渐演变完善的,在这个过程中,开发模式、技术架构、...
  • qq_16681169
  • qq_16681169
  • 2016-03-14 15:00:05
  • 237

揭秘大型网站架构进化之路

丁浪,非著名架构师。关注高并发、高可用的架构设计,对系统服务化、分库分表、性能调优等方面有深入研究和丰富实践经验。热衷于技术研究和分享。声明:版权归丁浪作者本人所有,转载请联系作者本人。互联网上有很多...
  • g6U8W7p06dCO99fQ3
  • g6U8W7p06dCO99fQ3
  • 2018-01-03 00:00:00
  • 350

阿里云构建千万级别架构演变之路

前言     一个好的架构是靠演变而来,而不是单纯的靠设计。刚开始做架构设计,我们不可能全方位的考虑到架构的高性能、高扩展性、高安全等各方面的因素。随着业务需求越来越多、业务访问...
  • a964921988
  • a964921988
  • 2017-04-21 09:52:53
  • 1840

大型网站架构体系的演变(上)

互联网上有很多关于网站架构的各种分享,有些主要是从运维和基础架构的角度去分析的(堆机器,做集群),太关注技术细节实现,普通的开发人员基本看不太懂。 本文上篇将主要介绍大型网站基础架构的扩展,下篇则重点...
  • dinglang_2009
  • dinglang_2009
  • 2015-06-07 11:28:38
  • 13569
收藏助手
不良信息举报
您举报文章:揭秘大型网站架构进化之路
举报原因:
原因补充:

(最多只允许输入30个字)