MENU

PHP VLD扩展使用

• October 15, 2019 • Read: 122 • PHP

介绍:

VLD(Vulcan Logic Dumper)是一个在Zend引擎中,以挂钩的方式实现的用于输出PHP脚本生成的中间代码(执行单元)的扩展。 它可以在一定程序上查看Zend引擎内部的一些实现原理,是我们学习PHP源码的必备良器。

安装:

安装 vld 和安装 php 其他的扩展没有任何区别,下载源码、编译、安装等…

wget http://pecl.php.net/get/vld-0.16.0.tgz
tar zxvf vld-0.16.0.tgz
cd vld-0.16.0.tgz
/usr/local/php/bin/phpize
./configure --with-php-config=/usr/local/php/bin/php-config --enable-vld
make && make install

记得要修改 php.ini 启用 vld 扩展:

[vld]
extensions=vld.so

使用:

使用 vld 查看 opcode 也非常简单,主要传递参数-dvld.active=1来激活 vld 扩展即可。
举个例子:
新建一个 test.php 并写入内容:

<?php
$a = '123';
echo $a;

使用 php -dvld.active=1 test.php 来查看,显示结果:

[root@myitmx ~]# php -dvld.active=1 test.php
Finding entry points
Branch analysis from position: 0
1 jumps found. (Code = 62) Position 1 = -2
filename:       /root/test.php
function name:  (null)
number of ops:  3
compiled vars:  !0 = $a
line     #* E I O op                           fetch          ext  return  operands
-------------------------------------------------------------------------------------
   2     0  E >   ASSIGN                                                   !0, '123'
   3     1        ECHO                                                     !0
         2      > RETURN                                                   1

branch: #  0; line:     2-    3; sop:     0; eop:     2; out0:  -2
path #1: 0, 
123

更多详细的使用方式,网上也有很多,这里就不再一一列举了

参数:

-dvld.active 是否在执行PHP时激活VLD挂钩,默认为0,表示禁用。可以使用-dvld.active=1启用。

-dvld.skip_prepend 是否跳过php.ini配置文件中auto_prepend_file指定的文件, 默认为0,即不跳过包含的文件,显示这些包含的文件中的代码所生成的中间代码。此参数生效有一个前提条件:-dvld.execute=0

-dvld.skip_append 是否跳过php.ini配置文件中auto_append_file指定的文件, 默认为0,即不跳过包含的文件,显示这些包含的文件中的代码所生成的中间代码。此参数生效有一个前提条件:-dvld.execute=0

-dvld.execute 是否执行这段PHP脚本,默认值为1,表示执行。可以使用-dvld.execute=0,表示只显示中间代码,不执行生成的中间代码。

-dvld.format 是否以自定义的格式显示,默认为0,表示否。可以使用-dvld.format=1,表示以自己定义的格式显示。这里自定义的格式输出是以-dvld.col_sep指定的参数间隔

-dvld.col_sep 在-dvld.format参数启用时此函数才会有效,默认为 “t”。

-dvld.verbosity 是否显示更详细的信息,默认为1,其值可以为0,1,2,3 其实比0小的也可以,只是效果和0一样,比如0.1之类,但是负数除外,负数和效果和3的效果一样 比3大的值也是可以的,只是效果和3一样。

-dvld.save_dir 指定文件输出的路径,默认路径为/tmp。

-dvld.save_paths 控制是否输出文件,默认为0,表示不输出文件

-dvld.dump_paths 控制输出的内容,现在只有0和1两种情况,默认为1,输出内容

备注:

如果经常需要查看 opcode , 而每次在命令中传递参数避免麻烦的话,可以将以上 vld 的参数配置在 php.ini 文件中

[vld]
extensions=vld.so
vld.active=1
vld.vld.verbosity=3
vld.execute=0

从而避免手动使用参数来传递 vld 配置。

Archives QR Code
QR Code for this page
Tipping QR Code