Chinaunix首页 | 论坛 | 博客
  • 博客访问: 69686
  • 博文数量: 67
  • 博客积分: 1334
  • 博客等级: 中尉
  • 技术积分: 670
  • 用 户 组: 普通用户
  • 注册时间: 2011-03-08 10:56
文章分类

全部博文(67)

文章存档

2016年(2)

2015年(2)

2012年(9)

2011年(54)

我的朋友
最近访客

分类: 系统运维

2011-09-08 14:05:48

    PHP测试方案
一、    性能测试(xhprof)
1)、安装
Wget
tar xzvf xhprof-0.9.2.tgz
cd xhprof-0.9.2/extension
/usr/local/php-5.3.5/bin/phpize
./configure –with-php-config=/usr/local/php-5.3.5/bin/php-config
make && make install

2)、配置PHP
在php.ini文件中加入xhprof.so模块
extension = /usr/local/php-5.3.6/lib/php/extension/xxxx/xhprof.so

保存并关闭,然后重启PHP

把xhprof_lib和xhprof_html两个目录拷贝到网站的根目录”xxx.xxxx.com/xhprof/”下,

2、使用
在需要做性能测试的地方加入
开始:
// XHPROF_FLAGS_CPU
// XHPROF_FLAGS_MEMORY
// XHPROF_FLAGS_NO_BUILTINS 跳过内置函数
// 要设定要忽略的函数列表,可以在分析时给xhprof_enable函数 指定第二个参数[是个可选参数], 如:
xhprof_enable(XHPROF_FLAGS_MEMORY,
        array(
'ignored_functions' => array(
'call_user_func',
'call_user_func_array'
    )
    )
);

xhprof_enable(XHPROF_FLAGS_CPU + XHPROF_FLAGS_MEMORY);
结束:
$xhprofData = xhprof_disable();
define('XHPROF_ROOT', Yii::getPathOfAlias('webroot.xhprof'));

include_once(XHPROF_ROOT . '/xhprof_lib/utils/xhprof_lib.php');
include_once(XHPROF_ROOT . '/xhprof_lib/utils/xhprof_runs.php');
$xhprofRuns = new XHProfRuns_Default();
$runId = $xhprofRuns->save_run($xhprofData, ' ');
echo "{$runId}&source= ";

然后就可以根据上面的地址查看

这样就可以查看到每个函数调用所消耗的CPU、内存、执行时间等

查看单一报告:
{$runId}&source=
查看对比报告:

查看汇总报告:
1,2,3&source=
加权汇总 :进一步假设,上述3个运特分别对应三种程序,p1.php,p2.php和p3.php ,通常以20%,30%,50%概率混合:要查看汇总报告所对应的加权平均数这些运行使用:
1,2,3 &wts=20,30,50&source=


二、    压力测试
命令:
ab –c 256 –n 100000

-c  并发数
-n  总请求次数
-t  总请求时间,超过5万次结束


服务器压力测试参考数据:
1、    CPU (nginx、PHP、MYSQL)   top
2、    内存(nginx、PHP、MYSQL)    free
3、    队列
4、    I/O
5、    网络流量


两种测试结合进行, 压力测试由低到高, 并且观察服务器的资源占用情况。 在压力测试的同时, 使用性能测试工具xhprof结合起来测试, 看看瓶颈是在哪里, 什么地方比较占用资源等。

//demo

function a(){

 echo 'test it';
}

xhprof_enable(XHPROF_FLAGS_CPU + XHPROF_FLAGS_MEMORY);
a();
$xhprof_data = xhprof_disable();  

include_once "xhprof/xhprof_lib/utils/xhprof_lib.php";
include_once "xhprof/xhprof_lib/utils/xhprof_runs.php"; 
 
$xhprof_runs = new XHProfRuns_Default(); 
 
$run_id = $xhprof_runs->save_run($xhprof_data, "sourcejoy");  

//echo "ttttt
";
echo "";

?>



 

阅读(1157) | 评论(0) | 转发(0) |
0

上一篇:没有了

下一篇:cakephp学习

给主人留下些什么吧!~~