从架构层面谈web加载优化(个人整理)
最近听了阿里一位大牛的讲座,讲web架构优化对网页加载的影响,看完之后对他所讲的一些优化方法进行一些总结和整理,发现收获还是蛮多的,下面多为个人整理和个人见解,希望有说的不对的,能及时指出
1.DNS解析优化
1.1利用TTL:利用TTL:因为DNS解析时,都是逐层查找DNS缓存,最后去跟服务器查询,而缓存有是有一定的生命周期,即Time To Live,而如果能快速的拿到缓存A记录,也就避免了我们逐层慢慢的查询了
1.2拆分域名:浏览器对于同一域名下文件同步请求是有上限的,比如ie8,同一域名下文件,同一时间只能发起6个请求,这时候拆分域名的重要性不言而喻
1.3DNS prefetch:拥有DNS prefetching属性的域名在用户点击前就已经在后台解析,而域名解析和内容载入都是串行网络的操作,故此能减少等待时间,即DNS预解析,在meta元标签里先告知浏览器要进行DNS预解析,然后通过link标签进行强制DNS预解析
2.TCP建联优化(即对rwnd,cwnd的处理)
2.1流量控制:即对接受窗口(rwnd)的处理,考虑丢包的情况,对于传输数据有一定上限限制,并进行相互的告知,防止接收方处理能力跟不上接受能力
2.2慢启动:即拥塞窗口(cwnd)的慢步启动,表示接收方确认前的最大允许传输的未经确认数据,而cwnd的初始值一般都很小,往往在得到接收方回应后,其cwnd值会缓步增加(这和宠物喂食是一样的道理,开始的时候,我们会放很少的狗粮,当发现不够时,我们在缓步增加他的喂食量),而cwnd的值也不会无止境的增长,当出现网络过载时,cwnd又会骤降--------------慢启动对于视频加载影响可能并不是很明显,但是web访问时,往往数据量并不是很大,可能我们的cwnd还在初尝试的增加中,web已经加载完毕了,所以说在应用于web优化时,我们慢启动的cwnd初始值可以适当的高一点,Google给出cwnd的建议值是10MSS
3.CDN加速
这块我感觉很多人都用过,最常见的就是script src引用一个cdn地址的文件,其原理就是就近原则
4.请求合并(减少http请求)
这块可行的方法太多了,举几个个人平时碰到的解决方案
4.1gulp/grunt合并文件
4.2雪碧图
4.3图片以base64码形式引入,每一个src都是一个http请求,而当img以base64的形式引入时,并不是外部载入,解析的事就交给了浏览器,从而减少了http请求
5.重定向优化
这边谈到的重定向肯定是临时重定向,说明白点就是我们一个form表单post给一个php文件,这时候浏览器就会被告知要跳转到另外一个url,这就是一步重定向。而重定向对于用户体验的影响就不要我多说了,SPA形式的应用之所以流行,很大一部分原因就是其数据交互都是采用ajax,即无缝刷新,每一个url的重刷新都是对用户耐心的一个消磨。但是凡事无绝对,重定向对于PC端有无疑是不可或缺的,比如说网易的官网,他需要对用户流量进行跟踪,从而知道网站哪些是热点区域,那些需要改良。所以我们不能一味的说避免重定向,而是有选择性的对其优化
当然重定向还有一个很突出的有点,对于有下载需求的客户,我们在收到他的下载请求后,获取他的ip,分配给他一个离他较近的下载地址,对不同用户进行不同的http重定向,从而加快用户体验
6.NS部署,Anycast
前者是在看云栖大会时看到的一个概念,百度之后也没有太大的效果,希望有大牛可以告知。后者大概是指一种就近原则的通信手段=0=一知半解
7.缓存
7.1动态页面静态缓存:虽然网页中部分数据使用动态读取得到的,但是直接缓存整个静态,将动态数据静态化,而数据库有变动时,在下次访问静态页面时,更换缓存
7.2缓存查询结果:同样的道理,这时候不对页面进行静态缓存,而是对查询结果缓存,减少对数据库的查询操作,同样减少了用户的加载时间
8.请求异步
这块就不多说了,大部分人应该在开发中常用这种方法了
9.http 2.0
= o=这块自行百度,个人看完后只是一知半解,还不敢拿上台面评头论足
10.负载均衡
web负载均衡,ip负载均衡,反代,dns等等,应用场景也多彩多样,通过给服务器集群分配任务,从而加快进程的处理,又或者根据ip分配较近,空闲服务器进行服务
11.除了上述架构系统层面的优化办法,还有一些小技巧
11.1 lazy load针对图片资源较多,或类似贴吧那种结构的网站
11.2 LAMPN系统组合,即linux+apache+mysql+php+nginx的组合,对于静态加载和php动态请求完美分工,各取所长
11.3 代码优化:css选择器命名优化,针对浏览器从右向左扫描的原则,尽量单一命名,减少父子选择器的使用。Js代码优化,例如针对作用域链的代码优化..等等
11.4 代码压缩:这块gulp和grunt都可以胜任
从架构层面谈web加载优化(个人整理)的更多相关文章
- H5 缓存机制浅析 移动端 Web 加载性能优化
腾讯Bugly特约作者:贺辉超 1 H5 缓存机制介绍 H5,即 HTML5,是新一代的 HTML 标准,加入很多新的特性.离线存储(也可称为缓存机制)是其中一个非常重要的特性.H5 引入的离线存储, ...
- Vue 网站首页加载优化
Vue 网站首页加载优化 本篇主要讲解 Vue项目打包后 vendor.js 文件很大 如何对它进行优化 以及开启Vue的压缩 和 nginx gzip 压缩的使用, 其他就是对接口优化等 1. v ...
- VS2013打开项目Web加载失败
今天打开一个好久没打开过的老项目,发现web加载失败,如图: 然后重新加载项目,提示: 一开始直接在网上找答案,结果看的答案都不靠谱,只好自己动手了, 先看了 这里面是基础配置:大概看过后,又去看了提 ...
- js资源加载优化
互联网应用或者访问量大的应用,对js的加载优化是不可少的.下面记录几种优化方法 CDN + 浏览器缓存 CDN(content delivery network)内容分发网络, 最传统的优化方式.其 ...
- Web加载资源问题
Web加载静态资源的时候是同步加载的,每次加载必须前一个加载完成后进行后一个加载,这个是由于javascript 去阻塞浏览器其它操作导致的 推荐文章:http://www.cnblogs.com/l ...
- JQuery浮动层Loading页面加载特效
之前做项目,经常需要一些浮动层加载Loading. 现在好多前端框架都能实现了,最常用的就是 artDialog 下面记录下当时的代码. <!DOCTYPE html PUBLIC " ...
- vue项目首屏加载优化实战
问题 单页面应用的一个问题就是首页加载东西过多,加载时间过长.特别在移动端,单页面应用的首屏加载优化更是绕不开的话题.下面我会写出我在项目中做的一些优化,希望大家能够相互讨论,共同进步. 我的项目vu ...
- vue加载优化策略
vue.js是一个比较流行的前端框架,与react.js.angular.js相比来说,vue.js入手曲线更加流畅,不管掌握多少都可以快速上手.但是单页面应用也都有其弊病,有时候首屏加载慢的让人捏舌 ...
- Multidex(二)之Dex预加载优化
Multidex(二)之Dex预加载优化 https://www.jianshu.com/p/2891599511ff
随机推荐
- 隐马尔科夫模型python实现简单拼音输入法
在网上看到一篇关于隐马尔科夫模型的介绍,觉得简直不能再神奇,又在网上找到大神的一篇关于如何用隐马尔可夫模型实现中文拼音输入的博客,无奈大神没给可以运行的代码,只能纯手动网上找到了结巴分词的词库,根据此 ...
- 前端常用的WindowsCMD命令
前面的话 在网上找了一些关于命令提示符CMD的资料,但是很多资料都是把所有的功能罗列出来,大部分都不会用到.所以,自己把常用的CMD命令总结如下,方便查阅 操作类 help 列出所有支持的指令及说 ...
- 来吧,HTML5之基础标签(下)
<dialog> 标签 定义对话框或窗口. <dialog> 标签是 HTML 5 的新标签.目前只有 Chrome 和 Safari 6 支持 <dialog> ...
- 动手做第一个Chrome插件
Chrome插件是令人惊讶的简单,一旦你弄懂它的工作和实现原理.它是由一部分HTML,一部分Js,然后混合了一个叫做manifest.json的Json文件组合而成的整体.这意味着你可以使用你最擅长的 ...
- Entity Framework 教程——DBContext
DBContext: 在之前的章节<创建实体数据模型>中,EDM为我们创建了SchoolDBEntities 类,它派生子System.Data.Entity.DbContext这个类,这 ...
- Visual Studio:error MSB8020(搬运)
状况如下: error MSB8020: The builds tools for v120 (Platform Toolset = 'v120') cannot be found. To build ...
- React Native环境配置之Windows版本搭建
接近年底了,回想这一年都做了啥,学习了啥,然后突然发现,这一年买了不少书,看是看了,就没有完整看完的.悲催. 然后,最近项目也不是很紧了,所以抽空学习了H5.自学啃书还是很无趣的,虽然Head Fir ...
- maven 快照
大型应用软件一般由多个模块组成,一般它是多个团队开发同一个应用程序的不同模块,这是比较常见的场景.例如,一个团队正在对应用程序的应用程序,用户界面项目(app-ui.jar:1.0) 的前端进行开发, ...
- 使用git进行源代码管理
git是一款非常流行的分布式版本控制系统,使用Local Repository追踪代码的修改,通过Push和Pull操作,将代码changes提交到Remote Repository,或从Remote ...
- Node.js 教程 01 - 简介、安装及配置
系列目录: Node.js 教程 01 - 简介.安装及配置 Node.js 教程 02 - 经典的Hello World Node.js 教程 03 - 创建HTTP服务器 Node.js 教程 0 ...