百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

所有IT架构师必须先知道的知识:什么样的网站才算是大型网站?

cac55 2024-09-27 06:59 27 浏览 0 评论

大型网站的特点:

  • 高并发、大流量:需要面对高并发用户,大流量访问。
  • 高可用:需要7 x 24小时不间断服务。
  • 海量数据:数据需要存储、管理,需要大量服务器。
  • 用户分步广泛、网络情况复杂:全球网络复杂,像国内还有各个运营商网络互通难的问题。
  • 安全环境恶劣:互联网开放性,使得网站易受到攻击。
  • 需求快速变更,发布频繁:快速迭代。
  • 渐进式发展:从小网站开始,逐渐发展成大站点。

大型网站的主要技术挑战

庞大的用户,高并发的访问和海量数据。任何简单业务在处理PB级数据或数以亿计的用户时,问题就会变得棘手。

大型网站架构的演化过程

初始阶段的网站架构

大多数小项目的初期架构都是这样。随着网站业务发展,1台服务器无法满足需求:用户越来越多,网站性能越来越差,越来越多的数据导致存储空间不足。

应用、数据库、文件分离

  • 应用服务与数据服务分离:提高性能,解决存储问题。【服务器专用化】
  • 应用服务器:处理业务,要求CPU强
  • 文件服务器:存储文件,要求存储容量大
  • 数据库服务器:存储数据、缓存、磁盘检索,要求内存、硬盘速度快

随着用户量增多,数据库压力大,会成为系统瓶颈。

用缓存改善网站性能

二八定律:80%的业务访问20%的数据。所以常用数据放入缓存,可以减少数据库的压力。

缓存分为两种:

  • 本地缓存:访问更快,但受应用服务器内存限制,且会出现和应用程序争用内存的情况。
  • 分布式缓存:集群方式,专用服务器作为缓存服务器,理论上不受内存容量限制。

目前只有单个应用服务器,且只部署了一个实例,其能够处理的连接数有限,在网站访问高峰期时,应用服务器会变成瓶颈。

使用应用集群改善网站的并发能力

一台服务器的处理能力不足时,不要考虑去换更强大的服务器,对于大型网站而言,不管多么强大的服务器,都满足不了网站持续增长的业务需求。最好的方式是添加更多的服务器来分担原有服务器的访问。

数据库读写分离

数据库还存在的的问题:使用缓存后,依然会有部分读操作(缓存没有命中,缓存过期等)和所有的写操作需要访问数据库。在网站用户达到一定规模后,数据库依然会因为负载较高成为系统瓶颈。

解决办法:采用数据库读写分离,两台数据库配置主从关系,从主库写数据,从从库读数据,主库的数据会同步到从库中。

为了便于应用程序能够透明地访问读写分离的数据库,所以在应用程序中使用专门的数据访问模块。

使用反向代理缓存和CDN加速网站响应:网络环境复杂,缓存前端静态资源

请求访问存在的问题:随着网站持续的发展,发现不同网络环境的用户访问速度不同。

解决办法:使用反向代理缓存和CDN加速网站响应。

CDN和反向代理的基本原理:都是缓存,区别在于CDN部署在网络提供商的机房,使用户在请求网站服务时,可以从距离自己最近的网络提供商机房获取数据;而反向代理则部署在网站的中心机房中,从用户请求达到中心机房后,首先访问的服务器是反向代理服务器,如果反向代理服务器中缓存着用户请求的资源,就将其直接返回给用户。

CDN和反向代理的目的:尽早返回数据给用户,一方面加快用户访问速度,另一方面减轻应用服务器的负载压力。

使用分布式文件系统和分布式数据库系统

随着网站业务发展,原有读写分离的数据库也不能支撑。另外,原有的文件服务器也无法满足需求了。

这时,需要使用分布式数据库和分布式文件系统。

分布式数据库是网站数据库拆分的最后手段,只有在单表数据规模非常庞大时才使用。

网站更常用的数据库拆分手段是业务分库,将不同的业务数据部署在不同的物理服务器上。



使用NoSQL和搜索引擎

随着业务越来越复杂,对数据存储和检索的需求也越来越复杂,网站需要采用NoSQL和非数据库查询技术比如搜索引擎。

业务拆分(分治)

网站过于复杂,将业务拆分。比如商城拆分为首页、店铺、订单、买家、卖家等产品线,归不同的业务团队负责。具体到技术,也会根据产品线划分,将一个网站拆分为多个应用,每个应用独立部署维护。

应用之间可以通过一个超链接建立关系(在首页的导航链接指向不同的应用地址),也可以通过消息队列进行数据分发,当然最多的还是通过访问同一个数据存储系统来构成一个关联的完整系统。


分布式服务

业务拆分越来越小,存储系统越来越大,应用系统整体复杂度呈指数型增加,部署维护越来越困难。由于所有应用都需要连接数据库,在数万台服务器的情况下,数据库连接会资源不足。

既然每个应用系统都需要相同的业务操作,比如用户管理、商品管理等,可以把这些共用业务抽取出来,独立部署。




相关推荐

Mac右键菜单如何设置?_mac 右键菜单

Mac的用户都知道,Mac和Windows很大的区别在于,Windows可以使用鼠标右键完成的很多快捷操作,例如右键剪切、右键新建文件、右键快速访问等等。在工作学习中,这种快捷操作会大大提高我们的工作...

Office局部加密隐藏信息_office隐藏修改痕迹

除了日常使用的图片、音视频文件外,我们还常常和别人共享使用一些Word或Excel办公文件。而这些文件中的部分内容,也许是我们不希望别人看到的。这时,就需要对Word文档或Excel表格中的部分数据实...

不常见但100%好用的电脑快捷键_最全的电脑快捷键

办公人士或者经常使用电脑的人已经熟悉了常见的Ctrl+C/V等快捷键,想要更高效、专业的操作技巧来提升工作效率。接下来,同创双子双子IT运维工程师帮忙整理了一些不太常见但非常有用的快捷键。比如Alt+...

U盘文件被隐藏怎么恢复 U盘文件恢复隐藏的方法

U盘文件被隐藏怎么恢复?U盘文件被隐藏其实这是中了一种U盘病毒,它会恶意的将U盘中的文件夹隐藏起来,采用常规的方法,都无法打开查看。这种U盘病毒会把文件夹的属性给篡改掉,文件设置被改成只读、隐藏,在文...

win7查看隐藏的文件怎么操作 win7如何打开隐藏文件

win7查看隐藏的文件怎么操作?在使用电脑时,有一些用户会将文件设置为隐藏属性,以保护隐私。此外,还有一些系统文件默认处于隐藏状态。那么,如何操作才能打开这些隐藏文件呢?小编今天在这就为大家分享一下w...

系统小技巧:八个实用设置 藏于桌面右键

我们除了在桌面上执行鼠标单、双击操作外,常常也会用右键菜单命令查看文件或显示属性等。其实,除此之外,桌面里还隐藏着不少可被我们利用的实用右键操作项目。下面的这些Windows10桌面右键操作技巧,不...

移动硬盘中的隐藏文件如何恢复显示?可尝试这些方法

在使用移动硬盘的过程中,有时我们可能会遇到一些文件突然变得不可见或“隐藏”的情况。这种情况可能是由于多种原因造成的,如文件系统错误、病毒感染或误操作等。面对隐藏的文件,许多用户可能会感到困惑和不知所措...

Win11怎么查看隐藏文件和文件夹?_如何查看windows隐藏文件夹

一般来说系统会对比较重要的文件和文件夹添加隐藏属性,很多朋友可能找半天都找不到,那么怎么找出这些隐藏文件和文件夹呢,今天系统之家小编来教大家Win11显示隐藏文件的设置方法,操作步骤其实挺简单的,希望...

隐藏电脑文件(夹)竟如此简单!再也不怕被偷窥了

导读:谁的电脑硬盘中还不存有一些珍藏多年的学习资料,可为了保护它们各位学习爱好者也真的是煞费苦心,不管是层层文件夹“套娃”隐藏也好,修改文件名甚至修改后缀名也好,效果都是非常差的,本期文章小君就聊一聊...

怎么打开隐藏文件夹?_文件夹怎么弄

有时在电脑上,我们会发现之前的文件或者文件夹不见了,很多人会觉得会不会是误删了文件之类的。其实还有一种可能,就是你的文件或者文件夹被隐藏起来了。怎么打开隐藏文件夹?一、文件或者文件夹被隐藏的原因隐藏是...

移动硬盘上的隐藏文件怎么能找出来

移动硬盘作为一种小巧而便携式的硬盘存储器,具备容量大、兼容性好、即插即用等优势,被广泛应用于办公和家庭生活中,那么在使用移动硬盘过程中,你是否遇到了文件被隐藏的问题呢?本文将介绍恢复移动硬盘隐藏文件的...

系统小技巧:“发送到”菜单问题巧解决

此前,我们已经通过本刊的一些文章熟悉了通过手动或软件的方法定制“发送到”菜单的基本方法。在使用“发送到”菜单的过程中,还可能会遇到一些问题。例如:“发送到”菜单越用越长,能不能在不编辑删减的情况下,调...

WIN 10系统介绍(21) 重要文件的隐藏 私密文件的保护 显示隐藏文件

大家好,今天介绍电脑中重要文件和文件夹的隐藏以及显示。在每个人使用的电脑中,都有一些个人的私密的资料,比如一些账目,或者个人的照片,信件,技术文档,视频等等的一些资料。我们可能不希望所有登录的用户,都...

状态栏在哪?手机+电脑+软件里的它 一篇讲清位置和功能

状态栏就是设备或软件里显示状态信息的区域,能让你快速知道时间、电量等情况。下面告诉你不同设备和软件里状态栏在哪儿、有啥用。手机上的状态栏位置:屏幕最顶端的窄条,不管用什么APP,基本都在这儿。显示...

excel隐藏的部分内容如何显示出来?3个方法帮助你!

excel隐藏的部分如何显示出来?你是否曾经在Excel中遇到过某些单元格被隐藏,或者某些数据在编辑时突然消失,让你感到困惑和无助?不要担心,今天我将向你揭示如何解决这些问题,让你轻松显示隐藏的部分。...

取消回复欢迎 发表评论: