高性能网站优化指南

  这篇文章主要介绍了高性能网站优化指南,本文总结14个优化技巧、注意事项、避免事项、优化规则等,须要的朋友能够参考下php

    性能黄金法则:mysql

    只有10%~20%的最终用户响应时间花在了下载HTML文档上。其他的80%~90%时间花在了下载页面中的全部组件上。web

    规则1 减小HTTP请求sql

    能够经过使用图片地图,CSS Sprites(有利有弊),内联图片(data:URL模式,IE不支持,不能被缓存),合并脚本和样式表。数据库

    规则2 使用内容发布网络express

    若是应用程序web服务器离用户更近,则一个HTTP请求的响应时间将缩短 ;浏览器

    若是组件web服务器离用户更近,则多个HTTP请求的响应时间将缩短。缓存

    内容发布网络(CDN)是一组分布在多个不一样地理位置的web服务器,用于更加有效地向用户发布内容。服务器

    规则3 添加Expires头网络

    web服务器使用Expires头告诉web客户端他可使用一个组件的当前副本,直到指定的时间为止。要求服务器与客户端的时钟严格同步,而且要在时间过时后在服务器配置中提供一个新的日期。

    Max-Age和mod_expires能够弥补Expires的不足。

    规则4 压缩组件

    从HTTp1.1开始,

    规则5 将样式表放在顶部

    逐步呈现,避免白屏

    规则6 将脚本放在底部

    HTTP1.1规范建议浏览器从每一个主机名并行下载两个组件,在下载脚本时,并行下载其实是被禁用的。

    缘由之一是脚本有可能使用document.write来修改页面内容,所以浏览器会等待,以确保页面可以恰当地布局;

    缘由之二是为了保证脚本可以按照正确的顺序执行,若是并行下载多个脚本,就没法保证响应是按照特定顺序到达浏览器。

    将脚本放在顶部将会阻塞对其后面内容的呈现,而且会阻塞对其后面组件的下载。

    规则7 避免CSS表达式

    表达式expression方法被其余浏览器忽略,可是对于IE来讲是一个有用的工具。可以在IE中设置属性,建立跨浏览器的一致体验。例如,IE[IE6,IE7(Quirk),IE8(Quirk]不支持min-width属性,用表达式的方法能够解决这一问题:

代码以下:

 

    width: expression(document.body.clientwidth<600?"600px": "auto");

    min-width: 600px;

    表达式的问题在于对其进行的求值的频率比人们指望的要高。他们不只在页面呈现和大小改变时求值,当页面滚动甚至用户鼠标在页面上移过期都要求值。咱们能够向CSS表达式中添加一个计数器来进行跟踪。

    表达式计数器的实例:

    http://stevesouders.com/hpws/expression-counter.php

代码以下:

 

    P {

    width: expression(setCntr(),document.body.clientwidth<600?"600px": "auto");

    min-width: 600px;

    }

    取表明达式的方法:事件处理器(Event Handlers)

    经过在onresize事件中设置样式的width属性来修正min-width问题。

    事件处理器的实例:

    http://stevesouders.com/hpws/event-handler.php

    当浏览器的大小改变时,这个例子使用setMinWidth()函数来修改全部段落元素的大小——

代码以下:

 

    function setMinWidth(){

    setCntr(); //用于显示求值次数

    var aElements = document.getElementsByTagName("p");

    for(var i=0;i<aElements.length;i++){

    aElements[i].runtimeStyle.width=(document.body.clientwidth<600?"600px": "auto");

    }

    }

    if(1!=navigator.userAgent.indexOf("MSIE")){

    window.onresize=setMinWidth;

    }

    这会在浏览器改变大小时中动态设置宽度,可是第一次呈现时这并不能恰当地设置段落大小,所以,页面还须要使用“一次性表达式”,经过表达式设置初始宽度。

    规则8 使用外部JavaScript和CSS

    规则9 减小DNS查找

    规则10 精简JavaScript

    精简VS混淆VS压缩

    规则11 避免重定向

    当Web服务器向浏览器返回一个重定向是,响应中就会拥有一个范围在3xx的状态码。这表示用户代理必须执行进一步操做才能完成请求。

    重定向影响的是HTML文档的下载。

    规则12 移除重复脚本

    规则13 配置ETag

    规则14 使Ajax可缓存

ECS的选择:

  1. CPU相对要高,drupal比较消耗CPU,开启OPCache
  2. 硬盘,选择高速IO硬盘,读写文件较快
  3. 按期备份相关文件
  4. 防火墙策略,建议修改SSH默认端口,以避免被攻击

数据库:

  1. 选择RDS,不推荐自建MySQL服务,RDS作好按期备份策略
  2. 作好相关mysql配置
  3. 多并发能够作MySQL主从配置

大文件图片:

  1. 推荐使用OSS,搭配相关Drupal模块
  2. 为节省OSS流量,能够配搭CDN,流媒体必定要经过OSS播放
相关文章
相关标签/搜索