教育房产时事环球科技商业
投稿投诉
商业财经
热点动态
科技数码
软件应用
国际环球
晨报科学
新闻时事
信息智能
汽车房产
办公手机
教育体育
生活生物

如何优化网站的访问速度

  最近小吴同学发现有诸多的小伙伴们对于如何优化网站的访问速度这个问题都颇为感兴趣的,大家也都想要及时了解到如何优化网站的访问速度相关信息,那么小吴同学今天就来为大家梳理下具体的关于这个问题的一些消息吧。
  首先,在HTTP请求之前需要做这些:
  获取IP。浏览器地址栏中输入网址并提交之后,首先它会在DNS本地缓存表中查找,如果有则直接告诉IP地址。如果没有则要求网关DNS进行查找,如此下去,当找到对应的IP后,返回给浏览器。
  建立TCP连接。当获取到IP之后,就开始与所请求的服务器完成三次握手建立TCP连接。
  连接建立后,就向服务器发出http请求。
  HTTP请求,首先会得到页面文件,然后解析页面文件中的资源文件,
  包括css, js, 图片等,再发请求获取这些资源文件。在HTTP 1.1请求中,
  多个请求是可以重叠进行的,但是页面文件必须要先到才能知道要去请求哪些资源文件。
  所以整个过程中有几个阶段,第一阶段是首字节获取时间,
  也就是从URL请求到服务器收到HTTP请求后返回响应的内容的时间,
  这其实并不只是DNS和建立连接的时间,对于动态页面来说,
  要由服务器将动态代码执行完毕返回页面代码才可以,
  于是包括运算和数据库操作啊这些都会直接增加首字节获取时间。
  而于静态文件来说,首字节获取时间通常是比较快的。
  但是如果与服务器之间的网络不畅,比如说服务器在国外,则会造成很长的延时。
  在阿里云的云监控中,可以任意设置HTTP监控点,来监控服务器的响应时间,
  比如说我设置了放在同一个服务器上的两个网站:
  这里可以明显看到对于需要调用数据库的Wordpress来说,
  响应时间明显比下面只使用了简单的XML读取的eitdesign要长得多。
  而对于eitdesign来讲,基本上响应时间是瞬间,这里就看出服务器物理距离带来的影响了,
  因为服务器在杭州,从杭州访问只要2ms,而从青岛访问则需要23ms。
  至于数据到服务器再返回的响应时间可以通过ping指令获取。
  话说很多人都用过的ping指令,但是貌似很多人只是用来看服务器通不通…
  先来说说ping的原理:发送一个ICMP回声请求消息给目的地并报告是否收到所希望的ICMP回声应答。
  理论上来说,ping发过去的数据大小对方也应该回复同样大小的数据,于是可以轻松的看出与服务器之间通讯的状态。
  所以如果ping的响应时间一直很稳定,突然有波动,可能是由于带宽突然被占满导致的,
  这时配合对于服务器资源的监控,可以轻松的看出来问题出在哪。
  在ping的同时不断刷新页面,可以看到某个瞬间明显时间变长的现象,就是这一瞬间带宽已经被占满了。
  第二个阶段是得到页面文件的时间,在页面文件得到之前,是不会请求任何资源文件的,
  因为还不知道页面上有哪些资源文件,所以这段时间也非常关键。
  第三阶段是获取head中各种资源文件的时间,资源文件是以在HTML页面中出现的顺序来加载的,
  所以head中的资源会优先被加载,head里主要是css和js文件,然后页面才会渲染出来,
  所以要特别注意head中所需资源的载入时间。毕竟在页面渲染出来之前,用户所看到的都是一片空白。
  第四阶段是获取剩下的资源文件的时间,这部分主要是图片动画视频等文件了,
  重要性不是那么高了,毕竟页面已经出来了,大部分用户觉得用几秒时间看着它们载入也是可以接受的。
  其实还有页面渲染时间,但是因为和载入同步进行,而且通常不会比载入更慢,所以可以忽略。
  测试工具
  想要直观的获取这些数据,可以直接看页面的时间线,也就是瀑布图,
  现在各大浏览器内置的调试工具都可以实现这个功能。以本网站和safari为例,
  可以看下图:首次访问(safari中可以通过shift+刷新按钮来忽略缓存):
  再次访问:
  从图中可以清楚的看到,共引用了47个资源文件,一共是2M的数据,首次访问总用时1.07秒,再次访问用时825ms。
  先来说说首次访问:第一行蓝色的这个是页面文件,总大小50.89KB,压缩过实际传输尺寸10.58KB,
  响应时间342ms,载入时间66.1ms。然后这个文件解析之后,就开始请求各个资源文件。
  这里可以看到两条虚线,蓝色的这一条是DOMContent事件触发时间,此处是635ms,
  表示当浏览器已经完成解析文档(但其他资源比如图片可以还没下载完成),
  而红色的这条是Load事件触发时间,这里是1.07秒,表示所有资源都已经加载完成了。
  首次访问时所有资源都要请求,而再次访问时就可以利用本地缓存数据加快资源载入速度了。
  所以对不常变化的静态资源设置一个过期时间,告诉浏览器在一定期间内都不需要重新载入这个资源。
  可以加快用户再次访问的速度,显著减少第四阶段的时间。
  这个时间线不仅可以在本地浏览器中查看,也可以在相关的测试网站上看到,
  例如阿里的阿里测, 还有Google Page Speed和Yahoo YSlow.
  有一个工具把Google Page Speed和Yahoo YSlow结合了一下,叫GTMetrix,也是不错的工具。
  同时这些网站也会针对站点提供优化的建议。
  还有个工具叫17CE,可以同时从不同地区的测试服务器测试响应时间和PING时间,
  可以用于了解不同地区用户的访问速度。
  优化方法
  好了,现在有了相关的基础知识和工具,就可以有针对性的进行优化了。下面来分别说一说各部分要如何来优化:
  第一阶段,服务器响应时间,这部分基本上没啥太好的方法了,如果是动态网站的话,
  主要以算法和数据库优化为主,还有使用AJAX异步读取数据之类的,其实是后端的事,
  这里就不展开讨论了。不过一个网站如果服务器顺应时间超过2秒,
  基本上可以认为这服务器已经挂了,通常应该控制在500ms以内,
  或许让人感觉并不明显,如果能控制在250ms以内就更好了。
  第二阶段,获取页面文件,首先页面文件通常都不大,而且都是纯文本。
  于是优化的方法就是开启Gzip压缩,开启方式,
  对于Apache来说,首先要把httpd.conf里的LoadModule deflate_module modules/mod_deflate.so前的#去掉,
  然后重启Apache,然后在.htaccess中加入:
  AddOutputFilter DEFLATE html xml php js css text/html text/plain
  Gzip压缩对于这种比较松散的纯文本效果还是比较明显的,比如说我的这个首页就从50K压缩到了10K。
  还有要使用外部link CSS文件,不要把样式表直接放入HTML页在,这样CSS文件可以设置缓存。
  第三阶段,head中的资源文件,主要是css和js文件,方法有这几个:
  使用GZip压缩。
  使用minify之后的js和css,原版用于修改,输出min版用于使用,虽然不利于阅读,但是尺寸明显减小。
  合并多个css和js文件,减少http请求数量。
  把不必要的js文件移到页面后面去加载,对于那些不影响渲染的js文件,移到第四阶段再加载可以减少页面显示时间。
  对于不常更新的文件设置缓存时间并使用OSS或CDN
  第四阶段,这一段才是真正的大数据量,现在通常用户的带宽都不是问题了,
  瓶颈主要出现在服务器上了,可以想想看,如果一个页面完全载入需要2MB的数据,
  那么如果服务器出口带宽只有1Mbps的话,则忽略各种延时不计,在只有一个用户访问的情况下,
  最快也需要16秒的时间才能传输完成这2MB的数据。这对于用户来说是不能忍的。
  于是对于阿里云的ECS来说,如果你是包月的,没有很高带宽的话,就要尽量减少一切从ECS上直接访问的资源。
  方法主要是使用OSS存储,CDN加速和GZip压缩。这具体的优化就很细致了,努力将ECS上直接访问的数据量减至最少,
  但是Wordpress很麻烦,有些系统自带的和插件里引用的js和CSS文件,不方便合并和改变位置…
  只能尽量优化。以我这个网站为例,之前在将所有图片都放入CDN之后,
  载入首页还是大概要有220KB的数据要从ECS上走,这样只有1Mbps带宽的话,至少需要2秒时间。
  后来又移动了主题内的所有图片和bootstrap,jquery至CDN,再加上GZip压缩,
  经过优化之后,现在只有80KB的数据,可以保证在1秒以内加载完成。
  其它需要注意的地方包括:
  在保证图片质量的前提下尽可能的压缩图片尺寸。
  如果要展示小图,不要在页面中resize大图,要直接使用小尺寸的图片。
  尽量针对静态文件单独使用无cookies的域名
  至于访问量巨大的网站,那更是节约每一个字节都很重要,还有更多的优化方法,可以具体参考Google Page Speed和
  Yahoo YSlow的页面评测结果,不过这两个服务器都在国外,所以响应时间会长很多,这一数据可以忽略。
  最后来说说如何设置缓存时间,对于Apache来说,
  首先要把httpd.conf里的LoadModule expires_module modules/mod_expires.so前的#去掉,然后重启Apache,
  然后在.htaccess中加入相应的代码就可以设置不同文件类型的缓存时间了,
  如下设置的是图片文件和JS文件1个月,图标文件1年:
  ExpiresActive OnExpiresByType image/jpg "access plus 1 month"
  ExpiresByType image/jpeg "access plus 1 month"
  ExpiresByType image/gif "access plus 1 month"
  ExpiresByType image/png "access plus 1 month"
  ExpiresByType text/x-javascript "access plus 1 month"
  ExpiresByType application/x-shockwave-flash "access plus 1 month"
  ExpiresByType image/x-icon "access plus 1 year"
  题外话
  其实这篇文章的诞生源于阿里云服务器的小故障,某一天开始响应时间变的非常长,以至于云监控报警,当时上去看了一下一度响应时间达到15秒以上…
  于是在想是发生什么了…就想尽各种办法开始优化自己的网站,虽然这故障很快修复了,但是有机会让我重新研究了一下页面加速的各种知识。让我清醒的意识到1Mbps带宽是多么多么的小…
  希望大家在这篇文章中能找到自己想要的东西,小小的加速一下自己的网站~~~

怎么折纸枪(7一12岁手工折纸枪)大家好,我是梅子做手工,每日分享一款手工教程,欢迎大家!大家小时候有没有玩过用纸折的玩具手枪呢?小时候看着哥哥们拿着玩具纸手枪就觉得特别厉害特别帅气,所以就缠着哥哥教自己怎么折。虽如何培养专注力(专注力训练712岁)前段时间,一位网友让孩子一个人在屋里写作业,自己偷偷用手机录下孩子写作业的过程发到了网上,这段视频立刻引起了不少父母的共鸣这不就是我家娃的真实写照吗?在视频录制的9分钟里,孩子真正天津大学怎么样(天津大学名气怎么样)制造业是国民经济的主体,是立国之本兴国之器强国之基。智能制造是我国制造强国战略的核心单元,是中国制造2025的主攻方向。近日,全国高校人工智能与大数据创新联盟公布了全国普通高校智能江西农业大学怎么样(江西农业大学在江西名气)一南昌大学南昌大学的开始应该是1921年或者是1958年,前身是1958年成立的江西大学和江西工学院。南昌大学医学院的前身是1921年成立的江西公立医学专门学校。占地面积8098亩兰州交通大学怎么样(兰州交通大学有名气吗)解读甘肃的4所高校,收分不高省内名气大,备受学生青睐提到甘肃省的高校,你是不是第一时间想到的就是兰州大学呢?很多人都在讲虽然他是211,但是他是政策性的211,其实说这些话的人都错华南师范大学怎么样(华南师范大学名气)教师,是一份令人尊重的职业,肩负传道授业解惑的重任,责任重大而又意义非凡。教师也是大家公认的铁饭碗,不少考生对师范类院校可谓是趋之若鹜。目前我国师范类院校众多,排行榜前十的,当属以视频怎么调色(手机图片调色用什么软件)蜗牛的摄影笔记一款非常实用的调色软件Snapseed是一款非常好用的手机调色软件,可以从手机浏览器中下载。图一打开Snapseed之后,点击添加图片,这样就可以将我们需要后期的图片如何把照片调亮(图片太暗了用手机怎么调亮)由于光线角度没有把控好,我们在拍照的时候经常可能把人像照片中人物的脸拍得发暗,让照片看上去黯淡无光,遇到这种情况应该怎么办呢?没关系,只要稍加后期处理就可以解决这个问题。怕后期麻烦ofo关联公司被列为被执行人执行标的约81万文章来源科技讯天眼查App显示,11月6日,ofo关联公司北京拜克洛克科技有限公司新增一条被执行人信息,执行标的约81万。北京拜克洛克科技有限公司成立于2015年8月,注册资本约3luna是哪个国家的(luna洗脸仪哪国便宜)每经编辑魏官红4月14日晚,美图手机在官方微博发布长文,回忆美图手机的发展历程,并再次宣布将调整手机业务,与小米战略合作,将美图手机品牌独家授权给小米。而在宣布把手机业务转交给小米比干怎么死的(比干为什么是财神)比干,商朝沫邑(今河南卫辉)人,贵为王室宗亲,也是纣王的叔父。天下林姓始祖。有千古第一忠臣的美誉。那么,比干是怎样从忠臣变成财神的呢?比干挖心,是大多数看过封神榜的小盆友的童年噩梦
怎么查微信以前的好友聊天记录吗(怎么恢复之前的聊天记录)怎么查微信以前的好友聊天记录吗(怎么恢复之前的聊天记录)微信现已成为我们最常用的谈天东西,由于微信的运用率非常高,我们也常常会收拾一下微信谈天记载和其他软件的缓存文件来腾出手机空间怎么查以前的微信聊天记录啊(怎么恢复之前的聊天记录)怎么查以前的微信聊天记录啊(怎么恢复之前的聊天记录)微信现已成为咱们最常用的谈天东西,由于微信的运用率非常高,咱们也常常会拾掇一下微信谈天记载和其他软件的缓存文件来腾出手机空间。但微信咋查以前的聊天记录(怎么恢复之前的聊天记录)微信咋查以前的聊天记录(怎么恢复之前的聊天记录)微信现已成为我们最常用的谈天东西,因为微信的运用率十分高,我们也常常会收拾一下微信谈天记载和其他软件的缓存文件来腾出手机空间。但有时微信能不能查以前删除的聊天记录(微信原始聊天记录怎么恢复)微信能不能查以前删除的聊天记录(微信原始聊天记录怎么恢复)微信现已成为我们最常用的谈天东西,由于微信的运用率非常高,我们也常常会收拾一下微信谈天记载和其他软件的缓存文件来腾出手机空微信能查己删的聊天记录吗(怎么恢复之前的聊天记录)微信能查己删的聊天记录吗(怎么恢复之前的聊天记录)微信现已成为我们最常用的谈天东西,因为微信的运用率十分高,我们也常常会收拾一下微信谈天记载和其他软件的缓存文件来腾出手机空间。但有微信能查一个月之前的聊天记录(如何恢复微信聊天记录)微信能查一个月之前的聊天记录(如何恢复微信聊天记录)微信现已成为我们最常用的谈天东西,因为微信的运用率十分高,我们也常常会收拾一下微信谈天记载和其他软件的缓存文件来腾出手机空间。但微信能不能查被删的聊天记录(聊天记录删除怎么找回来)微信能不能查被删的聊天记录(聊天记录删除怎么找回来)微信现已成为咱们最常用的谈天东西,由于微信的运用率非常高,咱们也常常会拾掇一下微信谈天记载和其他软件的缓存文件来腾出手机空间。但微信能不能查指定日的聊天记录(怎么查询微信的聊天记录)微信能不能查指定日的聊天记录(怎么查询微信的聊天记录)微信现已成为咱们最常用的谈天东西,因为微信的运用率十分高,咱们也常常会拾掇一下微信谈天记载和其他软件的缓存文件来腾出手机空间。清除了微信聊天记录怎么恢复(如何找回以前的微信聊天记录)清除了微信聊天记录怎么恢复(如何找回以前的微信聊天记录)互联网时代不知道大家有没有习惯,当你手机内存空间慢后又不舍得删除其他APP只有对微信缓存以及聊天记录下手了,也不难怪大家很多微信咋找回以前的聊天记录(如何恢复撤回的微信聊天记录)微信咋找回以前的聊天记录(如何恢复撤回的微信聊天记录)原来微信消息撤回,还能一键重新查看,我也是刚知道说起聊天应用大家都会想起微信。微信在每个人的手机中使用次数应该是所有应用排行榜找回删除的微信聊天记录(微信恢复以前聊天记录)找回删除的微信聊天记录(微信恢复以前聊天记录)你每天有多少时间停留在微信?你使用微信的频率有多高?不知不觉微信已经逐渐与我们的生活工作融为一体,成为必不可少的一部分。平时在使用手机