77百科网
当前位置: 首页 生活百科

网站服务器架构图(10类常见的网站服务器架构)

时间:2023-06-11 作者: 小编 阅读量: 1 栏目名: 生活百科

主要手段有使用CDN和反向代理。

几年前,面试的时候,我说我的目标是三年内成为一个架构师,现在,五年时间过去了,还是一名普通的码农,但是对网站架构还是很感兴趣,在这里分享给大家一些网站常用的架构,自己做过个人站,也就是下面的第一个层次,现在公司的网站达到了下文中提到的架构的第六层,更高的层次可能更大的网站会用到。

1. 初始阶段的网站架构

一般小型网站,没有太多访客,一般来讲只需要一台服务器就够了,这时应用程序(很多情况下就是我们的代码文件,比如php,html,js,css等)、数据库、文件(比如图片或者附件)等所有资源都在一台服务器上

2. 应用服务和数据服务分离

随着网站业务的发展和用户量的增加,一台服务器就无法再满足需求了。大量用户访问导致访问速度越来越慢,而逐渐增加的数据也会导致存储空间不足。这时就需要将应用和数据分离,应用和数据分离后整个网站使用 3 台服务器:应用服务器、文件服务器和数据库服务器。通常这三台服务器可以放在同一个机房,如果分布在不同的机房,最好有专线连接,否则会影响访问速度,容易出现异常,不过一般是在同一个机房部署。

3. 使用缓存改善网站性能

随着用户再增加,网站又会一次面临挑战:数据库压力太大导致整站访问效率再次下降,用户体验受到影响。一个网站,往往 80% 的业务访问集中在 20% 的数据上,比如在我们的网站中,用户登陆注册和玩游戏操作最为频繁,那么就需要对用户数据做缓存,当最频繁的请求过来的时候,优先从缓存中读取数据,而不用去查询数据库。这样就可以减少数据库的访问压力,从而提高整个网站的访问速度。常用的缓存有文件缓存和redis,memcache等,文件缓存通常在服务器本地存储,redis等可以使用单独的服务器。

4. 使用应用服务器集群改善网站的并发处理能力

使用缓存后,数据访问压力得到了缓解,但是单一应用服务器能够处理的请求连接有限,在网站访问高峰期,应用服务器就成了整个网站的效率瓶颈。使用分布式集群是网站解决高并发、海量数据问题的常用手段。这种情况下,更恰当的做法是增加一台服务器分担原有服务器的访问及存储压力。对网站架构而言,只要能通过增加一台服务器的方式改善负载压力,就可以以同样的方式持续增加服务器不断改善系统性能,从而实现系统的可伸缩性。通过负载均衡调度服务器,可以将来自用户浏览器的访问请求分发到应用服务器集群中的任何一台服务器上,如果有更多用户,就在集群中加入更多的应用服务器,使应用服务器的压力不再成为整个网站的瓶颈。应用服务器实现集群是网站可伸缩架构设计中较为简单成熟的一种,如下图所示:

5. 数据库读写分离

网站在使用缓存后,使对大部分数据读操作访问都可以不通过数据库就能完成,但是仍有一部分读操作(缓存访问不命中、缓存过期)和全部的写操作都需要访问数据库,在网站的用户达到一定规模后,数据库因为负载压力过高而成为网站的瓶颈。目前大部分的主流数据库都提供主从热备功能,通过配置两台数据库主从关系,可以将一台数据库服务器的数据更新同步到另一台服务器上。网站利用数据库的这一功能,实现数据库读写分离,从而改善数据库负载压力。如下图所示:

应用服务器在写数据的时候,访问主数据库,主数据库通过主从复制机制将数据更新同步到从数据库,这样当应用服务器读数据的时候,就可以通过从数据库获得数据。为了便于应用程序访问读写分离后的数据库,通常在应用服务器端使用专门的数据访问模块,使数据库读写分离对应用透明。

6. 使用反向代理和 CDN 加速网站响应

随着网站业务不断发展,用户规模越来越大,由于中国复杂的网络环境,不同地区的用户访问网站时,速度差别也极大。有研究表明,网站访问延迟和用户流失率正相关,网站访问越慢,用户越容易失去耐心而离开。为了提供更好的用户体验,留住用户,网站需要加速网站访问速度。主要手段有使用 CDN 和反向代理。如下图所示:

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

任何强大的单一服务器都满足不了大型网站持续增长的业务需求。数据库经过读写分离后,从一台服务器拆分成两台服务器,但是随着网站业务的发展依然不能满足需求,这时需要使用分布式数据库。文件系统也一样,需要使用分布式文件系统。如下图所示:

分布式数据库是网站数据库拆分的最后手段,只有在单表数据规模非常庞大的时候才使用。不到不得已时,网站更常用的数据库拆分手段是业务分库,将不同业务的数据部署在不同的物理服务器上。

8. 使用 NoSQL 和搜索引擎

随着网站业务越来越复杂,对数据存储和检索的需求也越来越复杂,网站需要采用一些非关系数据库技术如 NoSQL 和非数据库查询技术如搜索引擎。如下图所示:

NoSQL 和搜索引擎都是源自互联网的技术手段,对可伸缩的分布式特性具有更好的支持。应用服务器则通过一个统一数据访问模块访问各种数据,减轻应用程序管理诸多数据源的麻烦。

9. 业务拆分

大型网站为了应对日益复杂的业务场景,通过使用分而治之的手段将整个网站业务分成不同的产品线。如大型购物交易网站都会将首页、商铺、订单、买家、卖家等拆分成不同的产品线,分归不同的业务团队负责。

具体到技术上,也会根据产品线划分,将一个网站拆分成许多不同的应用,每个应用独立部署。应用之间可以通过一个超链接建立关系(在首页上的导航链接每个都指向不同的应用地址),也可以通过消息队列进行数据分发,当然最多的还是通过访问同一个数据存储系统来构成一个关联的完整系统,如下图所示:

10. 分布式服务

随着业务拆分越来越小,存储系统越来越庞大,应用系统的整体复杂度呈指数级增加,部署维护越来越困难。由于所有应用要和所有数据库系统连接,在数万台服务器规模的网站中,这些连接的数目是服务器规模的平方,导致数据库连接资源不足,拒绝服务。

既然每一个应用系统都需要执行许多相同的业务操作,比如用户管理、商品管理等,那么可以将这些共用的业务提取出来,独立部署。由这些可复用的业务连接数据库,提供共用业务服务,而应用系统只需要管理用户界面,通过分布式服务调用共用业务服务完成具体业务操作。如下图所示:

对于上文中提到的一些服务器架构常用技术,我在这里做一些简单描述,更深层次的了解大家也可以自行google或者百度。

1、负载均衡服务器

负载均衡服务器主要作用是实现某些类型服务器的规模扩展。比如对于系统前端的web服务器和后端的数据库服务器,想通过加服务器实现N 1横向扩展,通过多台服务器负载分担压力,负载均衡必不可少。

2、web服务器

最常见,内存要求不是很高但cpu要求较高,主要用于部署各种web应用,如带界面的web页面、不带界面的web服务、wcf等等。

3、缓存服务器

大中型网站,分布式缓存已是标配,缓存服务器专门用于部署分布式缓存,一般而言对内存和带宽要求较高。

4、消息队列服务器

队列是系统解耦利器,也是大中型分布式系统标配,没有队列,业务系统很容易高度耦合,系统吞吐量也会很快遭遇瓶颈。

5、文件服务器

分布式文件系统,专门用于存储业务系统需要的各种文件如图片、多媒体文件等。

6、索引服务器

用于网站全文索引,搜索必备。对内存和CPU要求较高,大型网站,通常还需要支持主从备份和容错,甚至多实例索引集群。

7、搜索服务器

通常需要部署多台,否则查询多了性能撑不住,对内存要求不高。有的中小型站点,索引和搜索服务器在物理和逻辑上都是同一台服务器。

8、作业服务器

主要用于后端应用程序大批量大数据量复杂业务逻辑的定时作业,大多数互联网公司标配,某些企业的定时调度框架是直接部署在web服务器上的,可以减少这里的所谓作业服务器。

9、数据库服务器

主要用于存储和查询数据。数据库已是各种系统实际上的标配,内存和CPU都要求极高,网络和硬件要求也不低。大中型网站还需要支持数据库的主从备份和容错,甚至多实例的数据库集群。

通常,大中型的互联网应用会经历一个从单一的数据库服务器,到Master/Slave主从服务器,再到垂直分区(分库),然后再到水平分区(分表,sharding)的过程。而在这个过程中,Master/Slave以及分库相对比较容易,对应用的影响也不是很大,但是分表会引起一些棘手的问题,比如不能跨越多个分区join查询数据,如何实现DB负载等等,这个时候就需要一个通用的DAL框架来屏蔽底层数据存储对业务逻辑的影响,使得底层数据的访问对应用完全透明化。

10、nosql服务器

海量数据处理的兴起,各种nosql产品层出不穷,nosql服务器主要用于处理海量数据,支持存储、查询、分片等。

web应用中,有两个一直是不好实现横向扩展或者由于历史遗留问题实现代价非常大的东西,如你所知,就是:A、数据库 B、网络带宽。

而某些nosql的出现很可能解决这个历史遗留难题,现在已经有nosql产品弥补了关系型数据库天生不支持横向扩展的缺点,在特定场景下正在替代关系型数据库。

11、Web 服务器与应用服务器的区别是什么?

严格意义上Web服务器只负责处理HTTP协议,只能发送静态页面的内容。而JSP,ASP,PHP等动态内容需要通过CGI、FastCGI、ISAPI等接口交给其他程序去处理。这个其他程序就是应用服务器。

比如Web服务器包括Nginx,Apache,IIS等。而应用服务器包括WebLogic,JBoss等。应用服务器一般也支持HTTP协议,因此界限没这么清晰。但是应用服务器的HTTP协议部分仅仅是支持,一般不会做特别优化,所以很少有见Tomcat直接暴露给外面,而是和Nginx、Apache等配合,只让Tomcat处理JSP和Servlet部分

Web服务器通常只需支持HTTP协议,单纯处理页面用的;而应用服务器提供的是客户端可以调用的方法,需要支持EJB JNDI JMX 等J2EE API。 比如,Apache属于Web服务器,Weblogic属于应用服务器。 不过,现在大多数应用服务器也包含了Web服务器的功能。

Web服务器一般指的是处理静态请求或转发http请求的服务器,而应用服务器一般是用来处理动态请求的服务器。两者并没有很严格的区别。

来源:cnblogs.com/111testing/p/7078635.html

回复“资源”,视频教程,微服务、并发,数据可调优等,微信搜索【Java知音】

回复“源码”,领取一些练手项目,完整可用的项目源码,微信搜索【Java知音】

    推荐阅读
  • 洛阳副省级城市有哪些(中西部地区十大地级市)

    目前来看,洛阳的综合实力在中西部地级市中,无疑是全面领先。公开资料显示,除了GDP总量外,洛阳在社会零售品总额、金融存贷款、财政收入、旅游收入等领域,都是中西部地级市中领先的。中长期来看,江西的赣州也是跃跃欲试,赣州的GDP总量必然也能入围中西部十大地级市。据悉,芜湖的各类人均指标均位居前列。

  • 路信汽车怎么样 路信汽修连锁怎么样

    一旦反馈质量问题成型,央视等渠道的曝光可以让车企进行大规模召回等全面整改。对于大众汽车质量问题,厂家会尽快召回车辆。“3·15”暴露出的问题大多是现象性问题,这种暴露出来的问题对于车企来说非常重要。即使在“3·15”前后,面对外部压力,车企的政府公关和媒体公关的重要性也会比平时大大提高,更像是公司内部公关总监的拜访。

  • 2022教资上半年考试报名时间(2022教资上半年考试报名时间笔试)

    (已结束)网上打印准考证:2022年3月7日—12日。成绩公布:2022年4月15日。不具备本法规定的教师资格学历的公民,申请获取教师资格,必须通过国家教师资格考试。国家教师资格考试制度由国务院规定。

  • 俄罗斯重要的铁路线(有必要规划建设几条接通俄罗斯的标轨铁路线)

    #俄方:俄可能将煤炭贸易转移至亚太#俄罗斯有2,500万吨的煤炭,要运往亚太地区,估计印度和我国都会有需要的。在这种情况下,现有的交通运输设施严重不足,最便利的方式就是铁路运输了,需要从俄罗斯接几条新的快速的铁路线到达我国。考虑让蒙古境内既有宽轨又有标轨贯通的铁路。

  • 天盛长歌知微和顾南衣(天盛长歌顾南衣和凤知微有吻戏吗)

    凤知微愕然看着他平静而自然品尝唇边酒液的姿态,童子般纯真清澈而气韵甜蜜。根据小说描写,凤知微和顾南衣属于通过酒液接吻,不过二人的感情不是爱情,凤知微对顾南衣是弟弟感觉,顾南衣单恋凤知微。顾南衣,是前代血浮屠第一高手顾衍之子,当代血浮屠宗宗主。顾南衣非常的爱凤知微,即使知道凤知微不喜欢自己,他也一直守护着她,之所以不和她在一起,是因为知道凤知微已经不需要自己了。

  • 手机卡在什么情况下会扣费(手机卡成扣费陷阱)

    正常商家的宣传中,流量一般是按月算的。虚商卡和物联卡的流量都是由商家向运营商购买,然后二次销售给用户的,存在着网络限速和流量虚标的问题。虚商卡和物联卡实际上用的还是三大运营商的基础通讯设备,只是其销售和售后等被独立商家承包。

  • 极速救援未播花絮(极速救援首播收视夺冠)

    由著名导演杨树鹏执导,青年演员张赫、王佳宇、魏哲鸣、金梦阳子等领衔主演的国内首部动作医疗救援剧《极速救援》正在湖南卫视青春进行时剧场热播中。该剧讲述了嘉安医院飞行医疗部的救援人员一次次穿梭云端勇赴险境,争分夺秒抢救生命的热血故事。由金梦阳子饰演的高冷霸气的徐海鸥主任在第一时间赶往矿难现场,变身极具狼性气质的“女斗士”,在紧要关头做出正确决断,稳准狠的识破矿洞负责人的背后阴谋,成功化解矿洞危机。

  • 微信公众号简介(微信公众号介绍)

    2016年1月18日,腾讯在北京发布消息称,中国政务微信公号已逾10万。2018年6月27日,微信官方宣布,微信公众平台上线开放转载功能,而转载文章也可以赞赏作者了。如因此给腾讯或第三方造成损害的,应当依法予以赔偿。用户同意在任何情况下不向他人透露帐户或密码信息。

  • 620开头的身份证是哪里的(620开头的身份证属于哪里)

    下面更多详细答案一起来看看吧!620开头的身份证是哪里的身份证620开头的是甘肃省的。其中6201为兰州,6202为嘉峪关,6203为金昌、6204为白银,6205为天水,6206为武威、6207为张掖,6208为平凉,6209为酒泉。甘肃,简称“甘”或“陇”,中华人民共和国省级行政区,省会兰州市。位于中国西北地区,东通陕西,西达新疆,南瞰四川、青海,北扼宁夏、内蒙古,西北端与蒙古接壤。总面积42.58万平方千米。

  • 三国时期董卓简介(三国人物之董卓)

    不过,从董卓对文人的态度来看,应该没有遭受“特别”的待遇。董卓因此以勇健侠气而成名,不久被任用为州里的兵马掾。凉州东南部与并州西南部二、升迁桓帝末年,董卓以六郡良家子为羽林郎。游侠剧孟,死后家无余财,相比之下,董卓这“侠义行为”,难说没有目的啊。任河东太守期间,董卓让大哥董擢,向在弘农隐居的张奂赠送一百匹“缣”,可是,张奂厌恶董卓为人,拒绝不受。结果,董卓驻兵河东,以观察形势变化。