当前位置: 首页 > news >正文

web建立虚拟网站大兴今日头条新闻

web建立虚拟网站,大兴今日头条新闻,商城类网站建设篇,汉中最新通知今天使用XHProf查找PHP性能瓶颈 XHProf是facebook 开发的一个测试php性能的扩展,本文记录了在PHP应用中使用XHProf对PHP进行性能优化,查找性能瓶颈的方法。 下载 网上很多是编译安装xhprof-0.9.4版本,应该是用php5,在php8.0下编译x…

使用XHProf查找PHP性能瓶颈

XHProf是facebook 开发的一个测试php性能的扩展,本文记录了在PHP应用中使用XHProf对PHP进行性能优化,查找性能瓶颈的方法。

下载

网上很多是编译安装xhprof-0.9.4版本,应该是用php5,在php8.0下编译xhprof-0.9.4各种报错(编译安装这个拓展 tideways 不会报错),php7、php8环境下,建议下载最新版本
https://pecl.php.net/package/xhprof

安装Xhprof扩展

cd /opt
wget https://pecl.php.net/get/xhprof-2.3.9.tgz
tar -zxvf xhprof-2.3.9.tgz 
cd xhprof-2.3.9
cd extension/
phpize
./configure
make && make install

修改php.ini

[xhprof]
extension=xhprof.so
xhprof.output_dir=/tmp

配置中xhprof.output_dir指定了生成的profile文件存储的位置,我们将其指定为/tmp。

对PHP进行性能分析

在XHProf扩展中,一共提供了四个函数用于对PHP进行性能分析。

xhprof_enable/xhprof_sample_enable函数用于开始XHProf性能分析,区别在于前者功能更加强大,而后者则是是以简单模式启动性能分析(简单记录了函数的调用栈信息),开销比较小。

xhprof_disable/xhprof_sample_disable函数用于停止性能分析,并返回分析的数据。

需要特别说明的函数是xhprof_enable,其他函数都是不需要提供参数的,而该函数则可以接受两个可选的参数,用于改变该工具的行为。

void xhprof_enable ([ int $flags = 0 [, array $options ]] )
  • flags 该参数用于为剖析结果添加额外的信息,该参数的值使用以下宏,如果需要提供多个值,使用|进行分隔。

  • XHPROF_FLAGS_NO_BUILTINS 跳过所有的内置函数

  • XHPROF_FLAGS_CPU 添加对CPU使用的分析

  • XHPROF_FLAGS_MEMORY 添加对内存使用的分析

  • options 数组形式提供可选参数,在此处提供ignored_functions选项需要忽略的函数

比如下面的例子,同时对内存和CPU进行分析,并且忽略对call_user_funccall_user_func_array函数的分析。

xhprof_enable(XHPROF_FLAGS_MEMORY|XHPROF_FLAGS_CPU,['ignored_functions'    => ['call_user_func','call_user_func_array']]
);// 这里是PHP代码,比如业务逻辑实现等要被分析的代码部分
....$xhprofData = xhprof_disable();// $xhprofData是数组形式的分析结果
print_r($xhprofData);

注意,如果使用XHPROF_FLAGS_CPU选项对CPU占用也进行分析,在Linux环境下,会造成比较高的系统负载,因此不建议使用,而推荐只使用XHPROF_FLAGS_MEMORY,对内存的分析不会对系统造成太多负载。

形象化的查看分析结果

安装graphviz

使用xhprof_disable完成性能分析并且获取到分析结果之后,我们通常不会直接输出结果,因为这样的结果是以数组形式组织的,看起来并不直观,幸运的是,xhprof提供了基于web的图形界面对分析结果进行查看。

在使用之前,请先确保服务器安装了graphviz工具,否则在生成监控图表的时候回出现以下错误:

failed to execute cmd: " dot -Tpng". stderr: `sh: dot: command not found '

这里提示找不到dot命令,所以需要先安装graphviz

yum -y install graphviz

将xhprof安装包中的xhprof_html_和xhproflib目录放到服务器的web目录下

由于分析结果的查看工具是基于web的,因此,我们需要将xhprof安装包中的xhprof_html_和xhproflib目录放到服务器的web目录下,让xhprof_html目录中的内容对外可以访问。

比如我的测试服务器环境是使用vagrant搭建的CentOS,这两个目录放到/opt/xhprof-2.3.9目录下:

cp -r /opt/xhprof-2.3.9/xhprof_html/ /www/nginx/php/xhprof_html
cp -r /opt/xhprof-2.3.9/xhprof_lib/ /www/nginx/php/xhprof_lib

web服务器使用的是Nginx,因此,修改Nginx的配置文件nginx.conf中的配置如下:

server {location / {root   /www/nginx/php;#等于php;index  index.php index.html index.htm;}location ~ \.php$ {root           /www/nginx/php;fastcgi_pass   127.0.0.1:9000;fastcgi_index  index.php;fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; #支持解析php文件include        fastcgi_params;}

使用

修改我们的代码,是其能够将分析结果存放到xhprof.output_dir(上面在php.ini设置的xhprof.output_dir=/tmp)指定的目录中。

在 PHP 页面顶部加上:
xhprof_enable(XHPROF_FLAGS_NO_BUILTINS + XHPROF_FLAGS_MEMORY);
在页面底部加上:
$xhprofData = xhprof_disable();
require '/vagrant/xhprof/xhprof_lib/utils/xhprof_lib.php';
require '/vagrant/xhprof/xhprof_lib/utils/xhprof_runs.php';$xhprofRuns = new XHProfRuns_Default();//数据会保存在php.ini中xhprof.output_dir设置的目录去中
$runId = $xhprofRuns->save_run($xhprofData, 'xhprof_test');//第二个参数是定义文件名称echo 'http://ip/xhprof/xhprof_html/index.php?run=' . $runId . '&source=xhprof_test';

变量$runId是本次请求生成分析结果的id,最后我们访问http://访问http://ip 页面输出了一个链接地址,使用该地址就可以看到本次请求的分析结果。

本次请求的分析结果

注意到中间的View Full Callgraph链接,通过该链接我们可以看到图形化的分析结果。

图形化分析结果

查看安装结果
[root@xxx /]# php -i | grep xhprof
xhprof
xhprof support => enabled
xhprof.collect_additional_info => 0 => 0
xhprof.output_dir => /tmp => /tmp
xhprof.sampling_depth => 2147483647 => 2147483647
xhprof.sampling_interval => 100000 => 100000
查看分析结果文件
[root@xxx /]# tree /tmp
/tmp
└── systemd-private-be08ad52244846b793f9a5c4600bb4dc-php-fpm.service-UXT6oP└── tmp├── 655f4470f21de.xhprof_test.xhprof└── 655f48cb6e9bf.xhprof_test.xhprof[root@xxx /]# cat /tmp/systemd-private-be08ad52244846b793f9a5c4600bb4dc-php-fpm.service-UXT6oP/tmp/655f4470f21de.xhprof_test.xhprof 
a:1:{s:6:"main()";a:4:{s:2:"ct";i:1;s:2:"wt";i:889;s:2:"mu";i:61200;s:3:"pmu";i:25216;}}

得到的是serialize后的数据

<?php
$str = 'a:1:{s:6:"main()";a:4:{s:2:"ct";i:1;s:2:"wt";i:889;s:2:"mu";i:61200;s:3:"pmu";i:25216;}}';
$arr = unserialize($str);
var_dump($arr);
array(1) {["main()"]=>array(4) {["ct"]=>int(1)["wt"]=>int(889)["mu"]=>int(61200)["pmu"]=>int(25216)}
}
http://www.tj-hxxt.cn/news/40076.html

相关文章:

  • 单页面网站建设手机上怎么制作网页
  • 备案时暂时关闭网站厦门百度关键词seo收费
  • 移动端网站开发视频谷歌商店安卓版下载
  • 在百度做网站优化设计四年级上册语文答案
  • 武汉营销型网站天津seo网站管理
  • 淄博网站建设.com站长工具查询系统
  • 茂名网站制作策划友情链接检测结果
  • 做pc端网站服务个人怎么做百度竞价
  • 地产建站规划阿里云自助建站
  • wordpress用什么服务网络seo关键词优化技巧
  • 未备案的网站可以百度推广吗南宁网站建设优化服务
  • 邯郸网站只做合肥网站维护公司
  • 政府网站一般用什么做西安seo建站
  • 喊别人做的网站不肯给代码网上销售平台
  • 宁夏小蚁人网站建设镇江seo快速排名
  • 京鑫建设集团网站全网搜索软件下载
  • 合肥网站建设策划方案uc推广登录入口
  • 幼儿园校园网站建设情况微信营销策略
  • 周口做网站的公司分析网站
  • 杭州滨江网站建设广告联盟代理平台
  • 哪个b2b网站做外贸好西安seo霸屏
  • wordpress界面菜单怎么弄江阴网站优化公司
  • 广 做网站蓝光电影下载江西百度推广公司
  • 西安网站开发的未来发展百度推广工具
  • 网页界面清空筛选下载seo经典案例分析
  • 德州制作网站哪家最专业千锋教育前端学费多少
  • 辽宁省网站备案系统知乎关键词排名工具
  • 单位网站建设收费标准搜索网站排行榜
  • 创建网站需要哪些要素什么叫做关键词
  • 什么是互联网行业宁德seo优化