`
wbj0110
  • 浏览: 1612224 次
  • 性别: Icon_minigender_1
  • 来自: 上海
文章分类
社区版块
存档分类
最新评论
阅读更多

测试网页性能工具

⑴Page Speed:

是开源 Firefox/Firebug 插件。网站管理员和网络开发人员可以使用 Page Speed 来评估他们网页的性能,并获得有关如何改进性能的建议。

⑵yslow:

YSlow可以对网站的页面进行分析,并告诉你为了提高网站性能,如何基于某些规则而进行优化。

安装方法:

安装:yslow直接在firefox组件查找,安装即可

Page Speed安装,使用火狐点开http://code.google.com/speed/page-speed/download.html,点击下载,火狐会自动安装

使用方法:

1)

wps_clip_image-17825

这里是如何解释的颜色代码分数:

· 高优先级。这些建议代表了最大的潜在的性能赢得。你应该首先解决这些项目。

· 中等优先级。这些建议可能代表较小的胜或更多的工作来实现。您应该解决这些项目的未来。

· 工作罚款或低优先级。如果显示建议,作为与“+”号表示,他们很可能代表未成年人胜。您应该只关注这些项目后,你处理的优先级较高的的。

· 只有信息的消息。无论这些项目不适用此页或有一个问题,在运行测试。

关于它的使用更详细的资料参考:http://code.google.com/intl/zh-CN/speed/page-speed/docs/using_firefox.html

2)

wps_clip_image-20965

视图显示了等级为网页的成绩单。整个字母等级为页面显示在顶部随着全面数值的表现。这个页面是基于22可分级的高性能网页的规则(见性能规则)。这些规则是列在按重要性的顺序,从最重要不重要。从 A 级到 F 级,A 级为最高。更详细的使用方法参考:http://www.yslow.net/show.php?tid=123

 

网站性能最佳惯例和规则

网站优化的原则是什么呢?这里推荐雅虎的23条网站优化军规

雅虎的卓越性能团队已经确定了23个军规:

1. 减少HTTP请求次数 
合并图片、CSS、JS,改进首次访问用户等待时间。 
2. 使用CDN 
就近缓存==>智能路由==>负载均衡==>WSA全站动态加速 
3. 避免空的src和href 
当link标签的href属性为空、script标签的src属性为空的时候,浏览器渲染的时候会把当前页面的URL作为它们的属性值,从而把页面的内容加载进来作为它们的值。测试 
4. 为文件头指定Expires 
使内容具有缓存性。避免了接下来的页面访问中不必要的HTTP请求。 
5. 使用gzip压缩内容 
压缩任何一个文本类型的响应,包括XML和JSON,都是值得的。旧文章 
6. 把CSS放到顶部 
7. 把JS放到底部 
防止js加载对之后资源造成阻塞。 
8. 避免使用CSS表达式 
9. 将CSS和JS放到外部文件中 
目的是缓存,但有时候为了减少请求,也会直接写到页面里,需根据PV和IP的比例权衡。 
10. 权衡DNS查找次数 
减少主机名可以节省响应时间。但同时,需要注意,减少主机会减少页面中并行下载的数量。 
IE浏览器在同一时刻只能从同一域名下载两个文件。当在一个页面显示多张图片时,IE 用户的图片下载速度就会受到影响。所以新浪会搞N个二级域名来放图片。 
11. 精简CSS和JS 
12. 避免跳转 
同域:注意避免反斜杠 “/” 的跳转; 
跨域:使用Alias或者mod_rewirte建立CNAME(保存域名与域名之间关系的DNS记录) 
13. 删除重复的JS和CSS 
重复调用脚本,除了增加额外的HTTP请求外,多次运算也会浪费时间。在IE和Firefox中不管脚本是否可缓存,它们都存在重复运算JavaScript的问题。 
14. 配置ETags 
它用来判断浏览器缓存里的元素是否和原来服务器上的一致。比last-modified date更具有弹性,例如某个文件在1秒内修改了10次,Etag可以综合Inode(文件的索引节点(inode)数),MTime(修改时间)和Size来精准的进行判断,避开UNIX记录MTime只能精确到秒的问题。 服务器集群使用,可取后两个参数。使用ETags减少Web应用带宽和负载 
15. 可缓存的AJAX 
“异步”并不意味着“即时”:Ajax并不能保证用户不会在等待异步的JavaScript和XML响应上花费时间。 
16. 使用GET来完成AJAX请求 
当使用XMLHttpRequest时,浏览器中的POST方法是一个“两步走”的过程:首先发送文件头,然后才发送数据。因此使用GET获取数据时更加有意义。 
17. 减少DOM元素数量 
是否存在一个是更贴切的标签可以使用?人生不仅仅是DIV+CSS 
18. 避免404 
有些站点把404错误响应页面改为“你是不是要找***”,这虽然改进了用户体验但是同样也会浪费服务器资源(如数据库等)。最糟糕的情况是指向外部 JavaScript的链接出现问题并返回404代码。首先,这种加载会破坏并行加载;其次浏览器会把试图在返回的404响应内容中找到可能有用的部分当作JavaScript代码来执行。 
19. 减少Cookie的大小 
20. 使用无cookie的域 
比如图片 CSS 等,Yahoo! 的静态文件都在 yimg.com 上,客户端请求静态文件的时候,减少了 Cookie 的反复传输对主域名 (yahoo.com) 的影响。 
21. 不要使用滤镜 
png24的在IE6半透明那种东西,别乱使,淡定的切成PNG8+jpg 
22. 不要在HTML中缩放图片 
23. 缩小favicon.ico并缓存

影响我的网站速度的因素

wps_clip_image-26065

测试几个主网页总结出影响我的网页速度的几个因素:

一级因素:

①启动压缩

②浏览器缓存

二级因素:

①提供压缩后的图片

找到原因下面就好办了,对症下药,下面将一个个解决。

解决办法:

  1. 开启压缩功能----gzip技术:文本页面(htm/css/js)启用gzip压缩后,一般可以压缩70%左右.

在 apache2.x 版本以上,需开启Deflate 模块。事实上,Apache2.x系列已经内置了这这个模块,因此,只需要安装时打开即可: 当然当时编译的时候没有打开,现在单独编译这个两个模块:mod_deflate模块

编译mod_deflate模块

1
2
3
4
5
cd /root/httpd-2.2.3/modules/filters
 
/usr/local/apache/bin/apxs -i -a -c mod_deflate.c //编译
 
/usr/local/apache/bin/apachectl restart  //重启apche

查看phpinfo

wps_clip_image-14508

编辑httpd.conf

添加下面这段话:

<ifmodule mod_deflate.c>

AddOutputFilterByType DEFLATE text/html text/plain text/css application/x-httpd-php application/x-javascript

DeflateCompressionLevel 9

SetOutputFilter DEFLATE

#DeflateFilterNote Input instream

#DeflateFilterNote Output outstream

#DeflateFilterNote Ratio ratio

#LogFormat '"%r" %{outstream}n/%{instream}n (%{ratio}n%%)' deflate

#CustomLog logs/deflate_log.log deflate

</ifmodule>

第一句:是支持压缩的文件格式

第二句:是压缩的等级,这里是最高等级

第三句:对所有站点进行压缩

更加详细的学习可以参考apache的官方手册:http://httpd.apache.org/docs/2.0/mod/mod_deflate.html

测试gzip安装是否成功:

下面二个测试网站,可以测试是否使用了gzip

http://www.whatsmyip.org/mod_gzip_test/

http://www.gidnetwork.com/tools/gzip-test.php

 

2.开启浏览器缓存:
  • php header函数-----网页的缓存

  • 这里使用php的header函数实现网页缓存

  

1
**************************************
1
 部分解释:
1
Last-Modified:浏览器第一次访问的标识符,作为以后是否访问过的一个重要标志
1
Etag:关于web资源的一个标识符,如断点下载,作为以后是否访问过的标志
1
Cache-Control:指定请求和响应遵循的缓存机制。在请求消息或响应消息中设置Cache-Control并不会修改另一个消息处理过程中的缓存处理过程。
1
请求时的缓存指令包括no-cache、no-store、max-age、max-stale、min-fresh、only-if-cached,
1
响应消息中的指令包括publicprivate、no-cache、no-store、no-transform、must-revalidate、proxy-revalidate、max-age。
1
各个消息中的指令含义如下: Public指示响应可被任何缓存区缓存。 Private指示对于单个用户的整个或部分响应消息,不能被共享缓存处理。
1
这允许服务器仅仅描述当用户的部分响应消息,此响应消息对于其他用户的请求无效。 no-cache指示请求或响应消息不能缓存 no-store用于防止重要的信息被无意的发布。
1
在请求消息中发送将使得请求和响应消息都不使用缓存。 max-age指示客户机可以接收生存期不大于指定时间(以秒为单位)的响应。
1
min-fresh指示客户机可以接收响应时间小于当前时间加上指定时间的响应。 max-stale指示客户机可以接收超出超时期间的响应消息。
1
如果指定max-stale消息的值,那么客户机可以接收超出超时期指定值之内的响应消息
1
<span style="color: #ff0000;">注意:这个页面缓存,不要在实时更新的页面或者有iframe页面上设置,否则很容易造成显示不能及时更新!我就在视频播放页面犯错了。</span>
1
 

1
<span style="color: #ff0000;">******设置了一个月的缓存!另外:content_encoding:gzip 说明gzip压缩安装成功</span>
1
 
  • Apache模块mod_expires=======对图像等资源的资源的缓存

  • 由于php的header函数只能缓存网页中的文本,但是图像,css,js资源等不能缓存,这里使用mod_expires模块对图片资源进行缓存

官方对mod_expires的说明;

这个模块控制服务器应答时的Expires头内容和Cache-Control头的max-age指令。有效期(expiration date)可以设置为相对于源文件的最后修改时刻或者客户端的访问时刻。

这些HTTP头向客户端表明了文档的有效性和持久性。如果有缓存,文档就可以从缓存(除已经过期)而不是从服务器读取。接着,客户端考察缓存中的副本,看看是否过期或者失效,以决定是否必须从服务器获得更新,官方手册:http://www.phpchina.com/manual/apache/mod/mod_expires.html

编译mod_expires模块:

Cd  /root/httpd-2.2.3/modules/metadata

/usr/local/apache/bin/apxs -i -a -c mod_expires.c //编译

 

编辑httpd.conf配置:添加下面内容

<IfModule mod_expires.c>

ExpiresActive on

ExpiresDefault "access plus 1 month"

ExpiresByType text/html "access plus 1 months"

ExpiresByType text/css "access plus 1 months"

ExpiresByType image/gif "access plus 1 months"

ExpiresByType image/jpeg "access plus 1 months"

ExpiresByType image/jpg "access plus 1 months"

ExpiresByType image/png "access plus 1 months"

EXpiresByType application/x-shockwave-flash "access plus 1 months"

EXpiresByType application/x-javascript      "access plus 1 months"

#ExpiresByType video/x-flv "access plus 1 months"

</IfModule>

解释:第一句--开启服务

第二句--默认时间是一个月

在下面是关于各种类型的资源的缓存时间设置,视频类的网站视频就不要设置缓存了!application/x-shockwave-flash

是指播放器,video/x-flv视频就不要经常更新了吧!

====================================

另外还有一种基于服务器缓存的使用:mod_cache的缓存方式,这个不仅支持http本地缓存,还支持hhtp代理缓存,

使用方法:

编译mod_cache,mod_mem_cache,mod_disk_cache 模块

Cd /root/httpd-2.2.3/modules/cache

/usr/local/apache/bin/apxs -i -a -c mod_cache.c cache_util.c cache_cache.c cache_storage.c cache_pqueue.c cache_hash.c //编译

/usr/local/apache/bin/apxs -i -a -c mod_mem_cache.c //编译

/usr/local/apache/bin/apxs -i -a -c mod_disk_cache.c //编译

编辑httpd.conf文件

添加:

<IfModule mod_cache.c>  

#内存缓存 

<IfModule mod_mem_cache.c>  

CacheEnable mem /usr/local/apache/htdocs/Mobile/share  

MCacheSize 4096  

MCacheRemovalAlgorithm LRU  

MCacheMaxObjectCount 100  

MCacheMinObjectSize 1  

MCacheMaxObjectSize 2048  

CacheMaxExpire 864000  

CacheDefaultExpire 86400  

#CacheDisable /php  

</IfModule>  

#硬盘缓存

<IfModule mod_disk_cache.c>  

CacheRoot /home/zhangy/cachetest  

#CacheSize 256  

CacheEnable disk /  

CacheDirLevels 4  

#CacheMaxFileSize 64000  

#CacheMinFileSize 1  

#CacheGcDaily 23:59  

CacheDirLength 3  

</IfModule>  

</IfModule>  

/usr/local/apache/bin/apachectl restart  //重启apche

关于参数说明和更多的学习参考:http://blog.51yip.com/apachenginx/898.html

http://apache.jz123.cn/mod/mod_cache.html

看一个成功后的效果图:图片资源设置了一个月的缓存

 

3.提供压缩后图片

对图片进行缩放处理以及其他效果处理,

这里不使用GD类库,使用ImageMagick来实现图片的压缩等等功能

分享到:
评论

相关推荐

    网站优化对网站的作用

    文章首先介绍了网站优化的基本思想,包括对用户、搜索引擎以及网站运营维护的优化,然后详细阐述了网站优化的主要内容,并对幻剑书盟网站的优化现状进行了问题分析,最后提出了针对性的优化建议。 绪论: 网站优化...

    网站优化10条

    网站优化10条 网站优化是一个很大的话题,有一些通用的原则,也有针对不同开发平台的一些建议。雅虎的工程师团队曾经给出过 35 个最佳实践,可以参照Best Practices for Speeding Up Your Web Site。同时,他们还...

    seo优化 网站优化

    网站优化不仅仅是关于关键词的堆砌,而是涵盖了多个方面,包括但不限于内容质量、用户体验、技术优化等。本篇文章将深入探讨SEO的基础知识,帮助你理解如何通过有效的优化策略提升网站的搜索引擎排名。 首先,我们...

    seo网站优化-资料

    SEO(Search Engine Optimization)是网站优化的重要组成部分,其主要目标是提高网站在搜索引擎中的自然排名,从而增加网站的可见度和吸引更多的潜在用户。在这个"seo网站优化-资料"的压缩包中,包含了多份关于SEO的...

    网站优化Seo教程网站优化Seo教程

    网站优化和SEO(搜索引擎优化)是提升网站在线可见度的关键技术,主要目的是为了在搜索引擎的自然搜索结果中获得更高的排名,从而吸引更多的有机流量。本教程将深入探讨这两个概念及其重要性,帮助你掌握有效提高...

    18个网站优化技巧

    ### 18个网站优化技巧:首页响应慢与首页速度优化 #### 一、引言 随着互联网技术的发展,用户对网页加载速度的要求越来越高。快速的页面加载不仅能够提升搜索引擎排名,还能显著改善网站转化率及用户体验。然而,...

    润心油茶网站优化方案

    【润心油茶网站优化方案】是一份针对中小型企业网站提升搜索引擎排名和网络营销效果的全面策划。该方案由宜春动网网络科技有限公司提供,旨在帮助企业在Google等搜索引擎中获得更好的左侧排名,从而增加网站曝光度,...

    网站优化计划方案

    网站优化计划方案是提升网站在搜索引擎中的可见性和用户体验的关键步骤,主要目标是提高搜索引擎排名,增加网站流量,最终实现业务增长。以下是对标题和描述中所提及知识点的详细说明: 一、SEO综合查询竞争度分析 ...

    网站优化.rar

    网站优化,特别是搜索引擎优化(SEO),是提升网站在搜索引擎结果页面排名、增加可见性和吸引潜在用户访问的关键策略。"网站优化.rar"这个压缩包可能包含了关于SEO优化的各种资源和工具,比如"网站优化.exe"可能是一...

    大型网站优化策略.ppt

    【大型网站优化策略】 在构建和管理大型网站时,优化策略是至关重要的,因为它直接影响到网站的可发现性、用户体验和搜索引擎排名。以下是一些关键的优化策略: 1. **关键词分析**: - **选择原则**:了解用户的...

    seo网站优化步骤

    SEO网站优化步骤 SEO流程操作及网站优化技巧网站的SEO流程,假设需要花一年的时间来完成。大致可以分为以下四个阶段: 第一阶段是准备期,主要要完成以下三个工作: 站点分析---形成站点分析报告 竞争对手分析---...

    旺道SEO网站优化大师

    **旺道SEO网站优化大师**是一款专业的搜索引擎优化(SEO)工具,旨在帮助用户提升网站在搜索引擎中的排名,增加流量,并优化关键词以获取更多的有机搜索曝光。SEO是网络营销的重要组成部分,通过改善网站的技术性能...

    网站优化和推广方法的分析.doc

    ### 网站优化与推广方法的深度解析 #### 一、网站优化的重要性与方法 **1.1 网站优化的必要性** 在互联网时代,网站优化成为了提升网站可见度的关键步骤之一。通过优化,可以使搜索引擎更容易识别并收录网站内容...

    最完整的网站优化工具

    网站优化是提升网页加载速度和用户体验的关键步骤,尤其在当今互联网竞争激烈的环境下,快速响应的网站更能吸引并留住用户。本文将详细介绍两个重要的网站优化工具——JSMIN和YUICompressor,以及它们如何帮助优化...

    网站优化手册:SEOBOOK(中文PDF版)

    《网站优化手册:SEOBOOK(中文PDF版)》是一本深度探讨搜索引擎优化(SEO)的专业指南,旨在帮助读者掌握如何提升网站在搜索引擎结果页的排名,从而增加网站的可见度和流量。SEO是互联网营销策略的重要组成部分,...

    深入理解网站优化:提升网站转化率的艺术与科学

    网站优化是互联网行业中至关重要的一个领域,其核心目标是提高网站的用户体验,进而提升网站的转化率。转化率是指访问者在网站上完成特定目标(如购买产品、填写表单或订阅服务)的比例。深入理解网站优化,既需要...

    大型网站优化方案

    在构建和运行大型网站时,优化是至关重要的...以上方案涵盖了大型网站优化的主要方面,实施这些措施可以显著提升网站的性能和用户体验。然而,每个网站都有其独特性,因此在实际操作中,应根据具体情况灵活调整和优化。

    seo网站优化发文章快速排名要点

    seo网站优化发文章快速排名要点,很多seo网站优化人员不知道文章怎样快速可以获取排名,那就来看看这个发文章要掌握的要点所在!

Global site tag (gtag.js) - Google Analytics