框架简述

用于前端的性能评测,基于雅虎的评分规则对页面进行评分的Firefox插件,从中可以看出我们页面上的很多不足,并且可以知道我们如何改进和优化,配合将测试报告发送到本地的ShowSlow平台以提供给开发人员随时查看。在Xvfb的辅助下,此框架最大的优点就是可以在无显示设备的环境下稳定运行。

使用环境:
ubuntu-10.10-desktop-i386

工具介绍
Xvfb:  主要就是通过内存计算模拟出图形界面,没有平常所见的操作界面,分为客户端和服务器

YSlow: 当Firefox浏览网页时,可以分析网站的页面(基于Yahoo 14条评分原则),并指出如何进行优化提高网站性能

ShowSlow:收集YSlow的测试结果并显示出来

Ubuntu:开源的Linux桌面操作系统。



LAMP环境安装配置
PHP 安装需要加载mcrypt  mysqli  模块

Apache

sudo apt-get install apache2 -y

PHP5

sudo apt-get install php5 -y
sudo apt-get install libapache2-mod-php5 -y
sudo apt-get install php5-mcrypt
sudo apt-get install php5-curl
sudo /etc/init.d/apache2 restart

Mysql

sudo apt-get install mysql-server -y

安装完成按提示设置root密码

配置Apache、PHP支持Mysql

sudo apt-get install libapache2-mod-auth-mysql

sudo apt-get install php5-mysql

sudo /etc/init.d/apache2 restart

SVN (可选)
sudo apt-get install subversion -y

安装Xvfb
sudo apt-get install xvfb

cd /var/www/
sudo wget http://showslow.googlecode.com/files/showslow_0.13.zip
unzip showslow_0.13.zip
mv showslow_0.13 showslow
cd showslow
cp config.sample.php config.php

vi config.php

根据实际情况修改$db,$user,$pass 根据实际情况修改
# Database connection information
$db = 'showslow';
$user = 'root';
$pass = 'dingtm';
$host = 'localhost';

登录MYSQL 导入数据
mysql -uroot -p
create database showslow;
use showslow;
source /var/www//showslow/tables.sql;
show tables;



创建测试页面列表,添加网址

vi /var/www/showslow/urls.txt

添加网址

http://www.elain.com/
http://wap.elain.com/
http://buy.elain.com/


修改Firefox的application.ini文件最后一段,避免Firefox崩溃后发送报告

    [Crash Reporter]
    Enabled=0

创建一份Firefox测试专用的Profiles (可选)

firefox -profilemanager

修改测试专用的Profiles的prefs.js.
vi /home/elain/.mozilla/firefox/vmdbz1tv.elain/prefs.js

注:不同的服务器vmdbz1tv.elain 这里生成的会不同(随机生成),此处我选默认目录,也可自建目录,创建prefs.js
# Mozilla User Preferences

# name firefox-prefs.js
# by dingtm
# date 2010-12-05

user_pref("app.update.lastUpdateTime.addon-background-update-timer", 1291608940);
user_pref("app.update.lastUpdateTime.blocklist-background-update-timer", 1291608793);
user_pref("app.update.lastUpdateTime.microsummary-generator-update-timer", 1291608894);
user_pref("app.update.lastUpdateTime.places-maintenance-timer", 1291607239);
user_pref("app.update.lastUpdateTime.search-engine-update-timer", 1291607685);
user_pref("browser.migration.version", 1);
user_pref("browser.places.importBookmarksHTML", false);
user_pref("browser.places.smartBookmarksVersion", 2);
user_pref("browser.startup.homepage_override.mstone", "rv:1.9.2.10");
user_pref("browser.tabs.warnOnClose", false);
user_pref("browser.warnOnRestart", false);
user_pref("distribution.canonical.bookmarksProcessed", true);
user_pref("extensions.PageSpeed.autorun", true);
user_pref("extensions.PageSpeed.beacon.minimal.url", "http://192.168.9.110/showslow/beacon/pagespeed/");
user_pref("extensions.PageSpeed.optimized_file_base_dir", "/tmp");
user_pref("extensions.enabledItems", "[email protected]:3.6,[email protected]:0.9rc2,[email protected]:1.6.0,[email protected]:2.1.0,{e3f6c2cc-d8db-498c-af6c-499fb211db97}:1.9.2,{972ce4c6-7e08-4474-a285-3208198ce6fd}:3.6.10");
user_pref("extensions.firebug.console.enableSites", true);
user_pref("extensions.firebug.currentVersion", "1.6.0");
user_pref("extensions.firebug.defaultPanelName", "YSlow");
user_pref("extensions.firebug.net.enableSites", true);
user_pref("extensions.firebug.previousPlacement", 1);
user_pref("extensions.firebug.script.enableSites", true);
user_pref("extensions.lastAppVersion", "3.6.10");
user_pref("extensions.update.notifyUser", false);
user_pref("extensions.yslow.autorun", true);
user_pref("extensions.yslow.beaconInfo", "grade");
user_pref("extensions.yslow.beaconUrl", "http://192.168.9.110/showslow/beacon/yslow/");
user_pref("extensions.yslow.cdnHostnames", "www.elain.com,data.elain.com,cdn.elain.com,s.elain.com,wap.elain.com,api.elain.com");
user_pref("extensions.yslow.optinBeacon", true);
user_pref("idle.lastDailyNotification", 1291608859);
user_pref("intl.charsetmenu.browser.cache", "ISO-8859-1, GB2312, UTF-8");
user_pref("network.cookie.prefsMigrated", true);
user_pref("places.last_vacuum", 1291608859);
user_pref("privacy.sanitize.migrateFx3Prefs", true);
user_pref("urlclassifier.keyupdatetime.https://sb-ssl.google.com/safebrowsing/newkey", 1294199157);
user_pref("xpinstall.whitelist.add", "");
user_pref("xpinstall.whitelist.add.36", "");

登陆到服务器的图形界面打开firefox  安装 firebug  yslow pagespeed  设置为自动运行。
 
1、先安装firebug  yslow  pagespeed火狐插件
2、打开Firefox输入:about:config(我保证会很小心的)
3、filter中输入:yslow
修改以下三条数据

extensions.yslow.beaconUrl = http://192.168.9.110/showslow/beacon/yslow/

extensions.yslow.beaconInfo = grade

extensions.yslow.optinBeacon = true

filter中输入:speed

修改这下两条数据:
 extensions.PageSpeed.beacon.minimal.url = http://192.168.9.110/showslow/beacon/pagespeed/
 extensions.PageSpeed.beacon.minimal.enabled = true

新建一个字符串

extensions.yslow.cdnHostnames

添加值:www.elain.com,data.elain.com,cdn.elain.com,s.elain.com,wap.elain.com,api.elain.com


4. 重启Firefox,

注:这里可这用localhost来代替IP,因为服务和测试的同个台服务器上,不同服务器这里一定上设置成为IP地址。

test_harness.pl

这个脚本是用Perl语言写的,我们主要需要用到的是display,profile,source这三个属性(具体作用ReadMe有解释),可以参考下我运行这个脚本的方式:

./test_harness.pl -display=:1 -source http://192.168.9.110/urls.txt -profile /home/elain/.mozilla/firefox/vmdbz1tv.elain/

执行上面的命令,我们通过外部机器访问http://192.168.9.110/showslow/ 即可查看测试结果

monitor.sh

自动调用之前编写test_harness.pl脚本,当我们将调用test_harness的一些参数添加进monitor后使用Linux的Cron就可以实现自动化测试了:)

注意将脚本文件夹的绝对路径赋值给Xvfb_PIDFILE,因为每次执行的时候系统会自动生成一个__xvfb.pid
--source http://192.168.9.110/urls.txt
--profile /root/.mozilla/firefox/vmdbz1tv.elain

创建定时任务

crontab -e

50 04 * * * /bin/sh /home/elain/showslow/monitor2.sh  >> /home/elain/showslow/monitor.log 2>&1

服务端配置完成

客户端配置方法:

注:如果客户端不配置也可这正常查看测试结果,但不可以手动推送数据到服务端上。

配置本地YSlow PageSpeed
 
1、先安装firebug  yslow  pagespeed火狐插件
2、打开Firefox输入:about:config(我保证会很小心的)
3、filter中输入:yslow
修改以下三条数据

extensions.yslow.beaconUrl = http://192.168.9.110/showslow/beacon/yslow/
extensions.yslow.beaconInfo = grade
extensions.yslow.optinBeacon = true

filter中输入:speed

修改这下两条数据:
 extensions.PageSpeed.beacon.minimal.url = http://192.168.9.110/showslow/beacon/pagespeed/
 extensions.PageSpeed.beacon.minimal.enabled = true

新建一个字符串(cdn数据,前端不使用CDN的跳过此步)

extensions.yslow.cdnHostnames

添加值:

www.elain.com,data.elain.com,cdn.elain.com,s.elain.com,wap.elain.com,api.elain.com


4. 重启Firefox,

查看测试报告的URL是:http://192.168.9.110/


排错指南:

1、在运行test_harness.pl脚本时出现的错误
 Can’t locate POE.pm in @INC (@INC contains: /etc/perl /usr/local/lib/perl/5.10.1 /usr/local/share/perl/5.10.1 /usr/lib/perl5 /usr/share/perl5 /usr/lib/perl/5.10 /usr/share/perl/5.10 /usr/local/lib/site_perl .) at test_harness.pl line 100.
    BEGIN failed–compilation aborted at test_harness.pl line 100.

若使用时出现以上错误,解决办法参考如下:

sudo perl -MCPAN -e shell
cpan> install POE


 Can't locate LWP/UserAgent.pm in @INC (@INC contains: /etc/perl /usr/local/lib/perl/5.10.1 /usr/local/share/perl/5.10.1 /usr/lib/perl5 /usr/share/perl5 /usr/lib/perl/5.10 /usr/share/perl/5.10 /usr/local/lib/site_perl .) at test_harness.pl line 100.
若使用时出现以上错误,解决办法参考如下:

sudo perl -MCPAN -e shell
cpan>install Bundle::LWP

如果提示YAML没有安装 (类似于XML的数据描述语言)

cpan>install YAML
cpan> exit


2、注册用户时出现以下错误(此处我怀疑官方的数据库文件中缺失)

Fatal error: Uncaught exception 'Exception' with message 'Can't prepare statement: Unknown column 'points' in 'field list'' in /usr/local/httpd/htdocs/showslow/users/User.php:655 Stack trace: #0 /usr/local/httpd/htdocs/showslow/users/modules/usernamepass/index.php(329): User::getUsersByEmailOrUsername('elain') #1 /usr/local/httpd/htdocs/showslow/users/register.php(47): UsernamePasswordAuthenticationModule->proce***egistration(Array, true) #2 {main} thrown in /usr/local/httpd/htdocs/showslow/users/User.php on line 655
说明数据不完整,
用phpmyadmin 建立一个points的表,类型 varchar  字段200