热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

(一)大型网站架构演化

成熟的系统架构是随着业务扩展而完善出来的,并非一蹴而就。不同业务特征的系统,会有各自的侧重。例如有的要解决海量的商品信息的搜索、下单,支付

成熟的系统架构是随着业务扩展而完善出来的,并非一蹴而就。不同业务特征的系统,会有各自的侧重。例如有的要解决海量的商品信息的搜索、下单,支付等,有的要解决海量用户的实时消息传输,有的要处理海量的搜索请求,他们都有各自的业务特性,系统架构也有所不同。

大型网站访问量和数据量二者缺一不可。

大型网站,其实最核心的功能就是计算和存储。一般DB是用来存储的,Application Server完成了业务功能和逻辑,是用于计算的。

一、原始的网站架构

最原始的架构,应用程序、数据库、文件都要部署在一台服务器上,如图:

这里写图片描述

应用程序各个功能模块之间是通过JVM内部的方法调用来进行交互的,而应用和数据库之间是通过JDBC进行访问的。

二、应用、数据、文件分离

当一台服务器不能满足性能需求,则将应用程序、数据库、文件各自部署在独立的服务器上,并且根据服务器的用途配置不同的硬件。

这里写图片描述

三、利用缓存改善网站性能

优化硬件的同时,软件也要进行性能优化,缓存技术就有了用武之地。使用缓存主要源于热点数据的存在,大部分网站访问都遵循28原则(80%的请求,最终落在20%的数据上),对热点数据进行缓存,减少这些数据的访问路径,提高用户体验。

缓存更加注重的是策略,也就是缓存命中率。

这里写图片描述

缓存实现的常见方式有本地缓存、分布式缓存、CDN、反向代理等。

本地缓存,就是将数据缓存放在应用服务器本地,可以存在内存中或文件,OSCache是常用的本地缓存组件。本地缓存特点是速度快,但因本地空间有限所以缓存数量有限。

分布式缓存,可以缓存海量的数据,并且扩展容易,常用的分布式缓存有MemcachedRedis

四、使用集群改善用用服务器性能

应用服务器作为网站的入口,会承担大量的请求数,应用服务器前面部署负载均衡服务器调度用户请求,根据分发策略将请求分发到多个应用服务器节点。

这里写图片描述

常用的负载均衡硬件有F5,价格很贵。软件有LVS、Nginx、HAProxy。LVS是四层负载均衡,根据目标地址和端口选择内部服务器,Nginx是七层负载,HAProxy支持四层、七层负载,可以根据报文内容选择内部服务器,因此LVS分发路径优于其他两种,而另外两种则更具配置性,如可以用来做动静分离(根据请求报文特征,选择静态资源服务器还是应用服务器)。

五、数据读写分离和分库分表

随着用户量的增加,数据库称为最大的瓶颈,改善数据库性能常用的手段是进行读写分离以及分表,读写分离就是将数据库分为读库和写库,通过主备功能实现数据同步。分库分表则分为水平切分和垂直切分,水平切分则是对一个数据库特大的表进行拆分。垂直切分则是根据业务不同来切换,如用户业务、商品业务相关的表放在不同库中。

这里写图片描述

六、使用CDN和反向代理提高网站性能

假如我们的服务器都部署在成都的机房,对于四川的用户来说访问是较快的,而对于北京的用户访问是较慢的,这是由于四川和北京分别属于电信和联通的不同发达地区,北京用户访问需要通过互联路由器经过较长的路径才能访问到成都的服务器,返回路径也一样,所以数据传输时间比较长。对于这种情况,常常使用CDN解决,CDN将数据内容缓存到运营商的机房,用户访问时先从最近的运营商获取数据,这样减少了网络访问的路径。比较专业的CDN运营商有蓝汛、网宿。

反向代理,是部署在网站的机房,当用户请求到达时首先访问反向代理服务器,反向代理服务器将缓存的数据返回给用户,如果没有缓存数据才会继续走应用服务器获取,减少了获取数据的成本。反向代理有Squd,Nginx。

这里写图片描述

七、使用分布式文件系统

用户一天天增加,业务量越来越大,产生的文件越来越多,单台的文件服务器已经不能满足需求。需要分布式的文件系统支撑。常用的分布式文件系统有NFS

八、使用NoSql和搜索引擎

对于海量数据的查询,我们使用nosql数据库加上搜索引擎可以达到更好的性能。并不是所有的数据都要放在关系型数据中。常用的NOSQL有mongodb和redis,搜索引擎有lucene。

这里写图片描述

九、将应用服务器进行业务拆分

随着业务进一步扩展,应用程序变得非常臃肿,这时我们需要将应用程序进行业务拆分,如百度分为新闻、网页、图片等业务。每个业务应用负责相对独立的业务运作。业务之间通过消息进行通信或者同享数据库来实现。

十、搭建分布式服务

这里写图片描述


推荐阅读
  • 本文介绍了关系型数据库和NoSQL数据库的概念和特点,列举了主流的关系型数据库和NoSQL数据库,同时描述了它们在新闻、电商抢购信息和微博热点信息等场景中的应用。此外,还提供了MySQL配置文件的相关内容。 ... [详细]
  • Java工程师书单(初级,中级,高级)
    简介怎样学习才能从一名Java初级程序员成长为一名合格的架构师,或者说一名合格的架构师应该有怎样的技术知识体系,这是不仅一个刚刚踏入职场的初级程序员也是工作一两年之后开始迷茫的程序 ... [详细]
  • 搭建Windows Server 2012 R2 IIS8.5+PHP(FastCGI)+MySQL环境的详细步骤
    本文详细介绍了搭建Windows Server 2012 R2 IIS8.5+PHP(FastCGI)+MySQL环境的步骤,包括环境说明、相关软件下载的地址以及所需的插件下载地址。 ... [详细]
  • 在单位的一台4cpu的服务器上部署了esxserver,挂载了6个虚拟机,目前运行正常。在安装部署过程中,得到了cnvz.net论坛精华区 ... [详细]
  • 一面自我介绍对象相等的判断,equals方法实现。可以简单描述挫折,并说明自己如何克服,最终有哪些收获。职业规划表明自己决心,首先自己不准备继续求学了,必须招工作了。希望去哪 ... [详细]
  • SeMITechnologies正在使用矢量搜索引擎Weaviate构建的内容。SeMI的首席执行官兼联合创始人BobvanLuijt说,它是一种独特的AI优先数据库,使用机器学习 ... [详细]
  •     系统采用jeeplus框架(ssm+redis+shiro+mongodb+redis),默认是做了JSP未做前后端分离,由于业务需要已经多终端使用的需求(H5、小程序等) ... [详细]
  • 前面刚有AWS开战MongoDB,双方“隔空互呛”,这厢又曝出2亿+简历信息泄露——MongoDB的这场开年似乎“充实”得过分了些。长期以来,作为“最受欢迎的NoSQL数据库”,M ... [详细]
  • 本文介绍了Composer依赖管理的重要性及使用方法。对于现代语言而言,包管理器是标配,而Composer作为PHP的包管理器,解决了PEAR的问题,并且使用简单,方便提交自己的包。文章还提到了使用Composer能够避免各种include的问题,避免命名空间冲突,并且能够方便地安装升级扩展包。 ... [详细]
  • 篇首语:本文由编程笔记#小编为大家整理,主要介绍了软件测试知识点之数据库压力测试方法小结相关的知识,希望对你有一定的参考价值。 ... [详细]
  • MySQL笔记_MySQL笔记1|数据库17问17答
    本文由编程笔记#小编为大家整理,主要介绍了MySQL笔记1|数据库17问17答相关的知识,希望对你有一定的参考价值。 ... [详细]
  • {moduleinfo:{card_count:[{count_phone:1,count:1}],search_count:[{count_phone:4 ... [详细]
  • nsitionalENhttp:www.w3.orgTRxhtml1DTDxhtml1-transitional.dtd ... [详细]
  • 【转】腾讯分析系统架构解析
    TA(TencentAnalytics,腾讯分析)是一款面向第三方站长的免费网站分析系统,在数据稳定性、及时性方面广受站长好评,其秒级的实时数据更新频率也获得业界的认可。本文将从实 ... [详细]
  • 博客_2018年博客总结
    本文由编程笔记#小编为大家整理,主要介绍了2018年博客总结相关的知识,希望对你有一定的参考价值。前言     ... [详细]
author-avatar
手机用户2602901563
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有