从架构层面谈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
随机推荐
- Canvas坐标系转换
默认坐标系与当前坐标系 canvas中的坐标是从左上角开始的,x轴沿着水平方向(按像素)向右延伸,y轴沿垂直方向向下延伸.左上角坐标为x=0,y=0的点称作原点.在默认坐标系中,每一个点的坐标都是直接 ...
- 13、零配置Struts2开发
Convention 插件 从 Struts 2.1 开始, Struts 可以使用 Convention 插件来支持零配置: Convention 插件完全抛弃配置信息, 不仅不需要使用 strut ...
- TypeScript为Zepto编写LazyLoad插件
平时项目中使用的全部是jQuery框架,但是对于做webapp来说jQuery太过于庞大,当然你可以选择jQuery 2.*针对移动端的版本. 这里我采用移动端使用率比较多的zepto框架,他跟jqu ...
- [.NET] 怎样使用 async & await 一步步将同步代码转换为异步编程
怎样使用 async & await 一步步将同步代码转换为异步编程 [博主]反骨仔 [出处]http://www.cnblogs.com/liqingwen/p/6079707.html ...
- [C#] C# 知识回顾 - 学会使用异常
学会使用异常 在 C# 中,程序中在运行时出现的错误,会不断在程序中进行传播,这种机制称为“异常”. 异常通常由错误的代码引发,并由能够更正错误的代码进行 catch. 异常可由 .NET 的 CLR ...
- the Zen of Python---转载版
摘自译文学习区 http://article.yeeyan.org/view/legendsland/154430 The Zen of Python Python 之禅 Beautiful is b ...
- Mysql基础代码(不断完善中)
Mysql基础代码,不断完善中~ /* 启动MySQL */ net start mysql /* 连接与断开服务器 */ mysql -h 地址 -P 端口 -u 用户名 -p 密码 /* 跳过权限 ...
- 看图理解JWT如何用于单点登录
单点登录是我比较喜欢的一个技术解决方案,一方面他能够提高产品使用的便利性,另一方面他分离了各个应用都需要的登录服务,对性能以及工作量都有好处.自从上次研究过JWT如何应用于会话管理,加之以前的项目中也 ...
- 微信小程序开发—快速掌握组件及API的方法
微信小程序框架为开发者提供了一系列的组件和API接口. 组件主要完成小程序的视图部分,例如文字.图片显示.API主要完成逻辑功能,例如网络请求.数据存储.音视频播放控制,以及微信开放的微信登录.微信支 ...
- [转]Java常用工具类集合
转自:http://blog.csdn.net/justdb/article/details/8653166 数据库连接工具类——仅仅获得连接对象 ConnDB.java package com.ut ...