CentOS 7nginx 1.14php 5.6
2. xhprof 版本
xhprof-0.9.4图形展示依赖:graphvizgraphviz-gdlibpng
3. 安装 xhprof
下载 xhprof-0.9.4.tgztar xvzf xhprof-0.9.4.tgzcd xhprof-0.9.4/extension执行 ?/usr/local/php-fpm/bin/phpize./configure ?--with-php-config=/usr/local/php-fpm/php-configmake && make install
然后,在 php.ini 中添加 xhprof.so
vim ?/usr/local/php-fpm/etc/php.ini添加:[xhprof]extension=xhprof.soxhprof.output_dir="/data/wwwroot/xhprof/output"
记得要创建 xhprof.output_dir 目录,给777 权限;
简单测试:
重启一下 php-fpm: /etc/init.d/php-fpm ?restart ;测试一下 xhprof.so 是否加载成功:/usr/local/php-fpm/bin/php -m ?| grep ?xhprof
4. 为 xhprof 添加 nginx 虚拟机
在 nginx 虚拟机目录增加一个 server:
server { ???????listen ?80; ???????server_name xhprof.dev; ???????root /data/wwwroot/xhprof; ???????index index.php index.html; ???????access_log /data/logs/nginx/xhprof/xhprof.dev.log custom; ???????error_log /data/logs/nginx/xhprof/xhprof.dev.log.err error; ???????rewrite_log on; ???????location ~* \.php$ { ??????????#fastcgi_pass ??127.0.0.1:9000; ???????????fastcgi_pass ??unix:/usr/local/php-fpm/run/php-fpm-www.sock; ???????????fastcgi_index ?index.php; ???????????fastcgi_param ?SCRIPT_FILENAME ?$document_root$fastcgi_script_name; ???????????include ???????fastcgi_params; ???????}}
注意:
- server_name 根据实际情况;
- root 根据实际情况;
- 创建日志文件路径;
- fastcgi_pass 根据实际情况而定;
5. 测试 xhprof web
将 xhprof-0.9.4 目录下 xhprof_html 和 xhprof_lib 两个目录移动或者复制到 web 的 root 路径 /data/wwwroot/xhprof :
cp ?-r /usr/local/src/xhprof-0.9.4/xhprof_html /data/wwwroot/xhprof/xhprof_htmlcp ?-r /usr/local/src/xhprof-0.9.4/xhprof_lib /data/wwwroot/xhprof/xhprof_lib
创建 xhprof 测试文件
cd ?/data/wwwroot/xhprof/vim ?test.php<?php//加载所需文件include_once "./xhprof_lib/utils/xhprof_lib.php";include_once "./xhprof_lib/utils/xhprof_runs.php";//随意定义一个函数function test($max){ ???for ($idx = 0; $idx < $max; $idx++) { ???????echo ‘‘; ???}}//定义测试方法function a(){ ???test(rand(1000,5000));}//开始分析xhprof_enable();//需要分析的函数a();//结束分析$xhprof_data = xhprof_disable();//实例化xhprof类$xhprof_runs = new XHProfRuns_Default();//获取当前当前页面分析结果$run_id = $xhprof_runs->save_run($xhprof_data, "xhprof_foo");echo "\nhttp://xhprof.dev/xhprof_html/index.php?run=$run_id&source=xhprof_foo\n";
测试:
在浏览器访问 http://xhprof.dev/test.php 结果:
可以看到,返回了一个带run_id 的 url,通过这个 url 再跳转访问就可以看到具体的测试结果了:
如果想查看图像,可以点击 [View Full Callgraph] :
注意:
一般,大家安装完之后,系统还不能马上画图,一般会报错:
Format: "png" not recognized. Use one of: canon cmap cmapx cmapx_np dot dot_json eps fig gv imap imap_np ismap json json0 mp pic plain plain-ext pov ps ps2 svg svgz tk vml vmlz xdot xdot1.2 xdot1.4 xdot_json
解决办法:
需要安装一些依赖的工具
yum ?install ?graphvizyum ?install ?libpngyum ?install ?graphviz-gd (刚开始我没有安装这个,总是报错)
6. 总结
以上的内容只是简单安装使用 xhprof ?工具,要真正用来测试 php 的性能,还需要再 php 代码中使用,如何添加结合,以后再研究。
php 性能分析工具 xhprof 使用
原文地址:http://blog.51cto.com/hellocjq/2329013