文档章节

利用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 性能分析与实验——性能的宏观分析

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

OneAPM蓝海讯通
2015/08/18
40
0
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

没有更多内容

加载失败,请刷新页面

加载更多

下一页

git +STS使用问题解决一

1. 2.点以一个pull就是更新代码 3.synchronize workSpace 同步代码,同SVN一致

森火
6分钟前
0
0
powerBi odbc 连接impala 实现自助分析

配置Impala以使用ODBC 可以将第三方产品设计为使用ODBC与Impala集成。为获得最佳体验,请确保支持您打算使用的任何第三方产品。验证支持包括检查Impala,ODBC,操作系统和第三方产品的版本是...

hblt-j
11分钟前
0
0
Purism FAQ

<font size="37" color="#006248" face="幼圆"> <p align="center"> Purism FAQ </p> </font> 原文:https://puri.sm/faq/ 原作者:Purism Team 翻译者:冰焰火灵X 1079092922@qq.com 文章许......

ICE冰焰火灵X
26分钟前
0
0
nginx+webdav

1、配置Nginx以支持WebDav: Webdav是nginx一个组件,默认编译nginx时是没有安装这个组件的。 如果跟应用公用一个nginx,需要重新编译安装nginx,重新安装前需要备份好原来的nginx.conf。 1....

yaukie
32分钟前
0
0
spring 事件

ContextRefreshedEvent Event raised when an {@code ApplicationContext} gets initialized or refreshed. ContextClosedEvent Event raised when an {@code ApplicationContext} gets clos......

Canaan_
43分钟前
1
0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部