文档章节

利用PHP的VLD查询OPCODE

刘纪君
 刘纪君
发布于 2013/03/31 21:32
字数 636
阅读 77
收藏 4

为了能更好的查看php的编译过程需要用VLD来查看php的编译的OPCODE代码:

1:下载 VLD扩展包:# wget http://pecl.php.net/get/vld-0.10.1.tgz  

2:安装:

# tar zxvf vld-0.10.1.tgz
# cd ./vld-0.10.1
# /usr/local/php/bin/phpize 或者直接phpize
# ./configure --with-php-config=/usr/local/php/bin/php-config --enable-vld
# make && make install

3:编辑php.ini文件加入vld扩张:extension="vld.so"#确保vld.so在扩张路径下面

然后需要重启Apache或者是nginx

<?php
$a = 1;
$b = $a++;
echo $b;
echo $a;

root@bogon no-debug-non-zts-20060613]# /usr/local/php/bin/php -dvld.active=1 /usr/src/source/test.php

Finding entry points
Branch analysis from position: 0
Return found
filename:       /usr/src/source/test.php
function name:  (null)
number of ops:  7
compiled vars:  !0 = $a, !1 = $b
line     # *  op                           fetch          ext  return  operands
---------------------------------------------------------------------------------
   2     0  >   ASSIGN                                                   !0, 1
   3     1      POST_INC                                         ~1      !0
         2      ASSIGN                                                   !1, ~1
   4     3      ECHO                                                     !1
   5     4      ECHO                                                     !0
   6     5    > RETURN                                                   1
         6*   > ZEND_HANDLE_EXCEPTION                                    

branch: #  0; line:     2-    6; sop:     0; eop:     6
path #1: 0,

  1. -dvld.active 是否在执行PHP时激活VLD挂钩,默认为0,表示禁用。可以使用-dvld.active=1启用。  
  2. -dvld.skip_prepend 是否跳过php.ini配置文件中auto_prepend_file指定的文件, 默认为0,即不跳过包含的文件,显示这些包含的文件中的代码所生成的中间代码。此参数生效有一个前提条件:-dvld.execute=0  
  3. -dvld.skip_append 是否跳过php.ini配置文件中auto_append_file指定的文件, 默认为0,即不跳过包含的文件,显示这些包含的文件中的代码所生成的中间代码。此参数生效有一个前提条件:-dvld.execute=0  
  4. -dvld.execute 是否执行这段PHP脚本,默认值为1,表示执行。可以使用-dvld.execute=0,表示只显示中间代码,不执行生成的中间代码。  
  5. -dvld.format 是否以自定义的格式显示,默认为0,表示否。可以使用-dvld.format=1,表示以自己定义的格式显示。这里自定义的格式输出是以-dvld.col_sep指定的参数间隔  
  6. -dvld.col_sep 在-dvld.format参数启用时此函数才会有效,默认为 “\t”。  
  7. -dvld.verbosity 是否显示更详细的信息,默认为1,其值可以为0,1,2,3 其实比0小的也可以,只是效果和0一样,比如0.1之类,但是负数除外,负数和效果和3的效果一样 比3大的值也是可以的,只是效果和3一样。  
  8. -dvld.save_dir 指定文件输出的路径,默认路径为/tmp。  
  9. -dvld.save_paths 控制是否输出文件,默认为0,表示不输出文件  
  10. -dvld.dump_paths 控制输出的内容,现在只有0和1两种情况,默认为1,输出内容 

© 著作权归作者所有

共有 人打赏支持
刘纪君
粉丝 29
博文 133
码字总数 59637
作品 0
郑州
高级程序员
私信 提问
PHP性能优化工具--vld

PHP性能优化工具--vld 孤独求学人2016-12-251 阅读 工具优化PHP性能 PHP性能优化工具--vld vld介绍 vld 是一个在Zend引擎中,以挂钩的方式实现的用于输出PHP脚本生成的中间代码(执行单元)的...

孤独求学人
2016/12/25
0
0
PHP安装VLD查看opcode

# wget http://pecl.php.net/get/vld-0.10.1.tgz # tar zxvf vld-0.10.1.tgz # cd ./vld-0.10.1 # /usr/local/php/bin/phpize 或者直接phpize # ./configure --with-php-config=/usr/local/p......

晨曦之光
2012/03/09
1K
2
PHP 性能分析与实验——性能的宏观分析

【编者按】此前,阅读过了很多关于 PHP 性能分析的文章,不过写的都是一条一条的规则,而且,这些规则并没有上下文,也没有明确的实验来体现出这些规则的优势,同时讨论的也侧重于一些语法要...

OneAPM蓝海讯通
2015/08/18
1K
2
PHP安装parsekit扩展查看opcode

也可以通过VLD查看,具体请看本人写的http://blog.csdn.net/21aspnet/article/details/7002644 安装parsekit扩展 http://pecl.php.net/package/parsekit 下载最新的 #wget http://pecl.php.......

晨曦之光
2012/03/09
357
0
PHP 性能分析与实验——性能的宏观分析

【编者按】此前,阅读过了很多关于 PHP 性能分析的文章,不过写的都是一条一条的规则,而且,这些规则并没有上下文,也没有明确的实验来体现出这些规则的优势,同时讨论的也侧重于一些语法要...

OneAPM蓝海讯通
2015/08/18
40
0

没有更多内容

加载失败,请刷新页面

加载更多

nuc970 uboot nand-boot,kernel, filesystem 烧录位置

一 烧写到Nand Flash **1.1 **相关文件说明 l BSP版本:nuc970bsp-release-20150519.zip l NuWriter版本:2015/04/28-V01,nuvoTon Nu-Writer V1.0 l 烧写文件: u-boot-spl.bin:负责将u-b......

CookieDemo
今天
1
0
python中sort和sorted函数小结

L.sort(cmp=None, key=None, reverse=False) sorted(iterable, cmp=None, key=None, reverse=False) 这样看,sorted函数只比sort函数多一个iterable参数,其余没什么不同,iterable是一个迭代......

上官夏洛特
今天
4
0
thinkphp 常用SQL执行语句总结

第一条:Db::tablera('vr_panomas')->where(['delete_time'=>0,'id'=>['in',$pids]])->field(['id'=>'id','post_thumb'=>'thumb','post_title'=>'title','post_tags'=>'tags','post_price'=>......

koothon
今天
6
0
支付宝返回状态resultStatus意思

上一篇集成支付宝的时候,会有一些支付宝返回的resultStatus,具体意思是: 9000 订单支付成功 8000 正在处理中 4000 订单支付失败 6001 用户中途取消 6002 网络连接出错 还有memo,意思就是...

RainOrz
今天
4
0
electron webview 页面加载事件顺序

1.did-start-loading 页面开始加载 2.load-commit 主页面文档加载 3.page-title-updated title 4.dom-ready 主页面 dom 加载完成 5.load-commit frame文档加载 6.did-frame-finish-load fram......

dubox
今天
6
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部