本文章是学习大型分布式网站架构的技术总结。对架构一个高性能,高可用,可伸缩,可扩展的分布式网站进行了概要性描述,并给出一个架构参考。一部分为读书笔记,一部分是个人经验总结。
单一应用架构拆分成垂直应用架构,解决了单一应用架构所面临的扩容问题,流量能分散到各个子系统中,且系统的体积可控,一定程度上降低了维护成本,提高开发效率; 但当垂直应用越来越多,达到一定规模时,应用之间相互交互、调用不可避免;否则不同系统之间存在着重叠的业务,容易形成信息孤岛,重复造轮子;此时,相对核心的业务将被抽取出来,作为单独的系统对外提供服务,打成业务之间的相互复用,系统也因此演变成分布式应用架构体系
一、大型网站的特点
二、大型网站架构目标
三、大型网站架构模式
四、高性能架构
以用户为中心,提供快速的网页访问体验。主要参数有较短的响应时间,较大的并发处理能力,较高的吞吐量,稳定的性能参数。
可分为前端优化,应用层优化,代码层优化,存储层优化。
前端优化:网站业务逻辑之前的部分;
浏览器优化:减少Http请求数,使用浏览器缓存,启用压缩,Css Js位置,Js异步,减少Cookie传输;
CDN加速,反向代理;
应用层优化:处理网站业务的服务器。使用缓存,异步,集群
代码优化:合理的架构,多线程,资源复用(对象池,线程池等),良好的数据结构,JVM调优,单例,Cache等;
存储优化:缓存,固态硬盘,光纤传输,优化读写,磁盘冗余,分布式存储(HDFS),NOSQL等;
原文:https://www.cnblogs.com/jccjcc/p/13054194.html