wget http://pecl.php.net/get/vld-0.11.2.tgz
tar zxf vld-0.11.2.tgz
cd vld-0.11.2
which phpize
/usr/bin/phpize
find / -name 'php-config'
/usr/bin/php-config
./configure --with-php-config=/usr/bin/php-config --enable-vld
echo $?
make && make install
ll /usr/lib64/php/modules/
vi php.ini
extension=vld.so
/etc/init.d/php-fpm restart
查看phpinfo()
====================案例:
vi demo.php
$a = ‘hello world’;
echo $a;
=====================源码分析:
[root@node2 yeqing]# php -dvld.active=1 ./demo.php
Finding entry points
Branch analysis from position: 0
Return found
filename: /home/yeqing/demo.php
function name: (null)
number of ops: 3
compiled vars: !0 = $a
line # * op fetch ext return operands
---------------------------------------------------------------------------------
2 0 > ASSIGN !0, 'hello+world%21%21'
3 1 ECHO !0
6 2 > RETURN 1
branch: # 0; line: 2- 6; sop: 0; eop: 2
path #1: 0,
hello world!!
================
行号、opcodes指令编号、脚本开始标记、结束标记、ZEND VM指令、返回值、ZEND VM指令对应的参数
opcodes手册:
http://php.net/manual/en/internals2.opcodes.list.php
================如上为VLD输出的PHP代码生成的中间代码的信息,说明如下
Branch analysis from position 这条信息多在分析数组时使用。
Return found 是否返回,这个基本上有都有。
filename 分析的文件名
function name 函数名,针对每个函数VLD都会生成一段如上的独立的信息,这里显示当前函数的名称
number of ops 生成的操作数
compiled vars 编译期间的变量,这些变量是在PHP5后添加的,它是一个缓存优化。这样的变量在PHP源码中以IS_CV标记。
op list 生成的中间代码的变量列表
使用-dvld.active参数输出的是VLD默认设置,如果想看更加详细的内容。可以使用-dvld.verbosity参数。
php -dvld.active=1 -dvld.verbosity=3 demo.php
其中:
-dvld.verbosity=3是VLD在当前版本可以显示的最详细的信息
如果我们只是想要看输出的中间代码,并不想执行这段PHP代码,可以使用-dvld.execute=0来禁用代码的执行
php -dvld.active=1 -dvld.execute=0 demo.php
读源码要学会一种精神: 顺藤摸瓜
参考文档:
http://www.php-internals.com/book/?p=C-php-vld
http://www.php-internals.com/book/?p=chapt02/02-03-02-opcode
http://php.net/manual/zh/internals2.ze1.zendapi.php
http://www.laruence.com/2011/03/04/1894.html
http://blog.pureisle.net/archives/2294.html
http://www.imsiren.com/archives/704
http://blog.csdn.net/siren0203/article/details/8085813
tar zxf vld-0.11.2.tgz
cd vld-0.11.2
which phpize
/usr/bin/phpize
find / -name 'php-config'
/usr/bin/php-config
./configure --with-php-config=/usr/bin/php-config --enable-vld
echo $?
make && make install
ll /usr/lib64/php/modules/
vi php.ini
extension=vld.so
/etc/init.d/php-fpm restart
查看phpinfo()
====================案例:
vi demo.php
$a = ‘hello world’;
echo $a;
=====================源码分析:
[root@node2 yeqing]# php -dvld.active=1 ./demo.php
Finding entry points
Branch analysis from position: 0
Return found
filename: /home/yeqing/demo.php
function name: (null)
number of ops: 3
compiled vars: !0 = $a
line # * op fetch ext return operands
---------------------------------------------------------------------------------
2 0 > ASSIGN !0, 'hello+world%21%21'
3 1 ECHO !0
6 2 > RETURN 1
branch: # 0; line: 2- 6; sop: 0; eop: 2
path #1: 0,
hello world!!
================
行号、opcodes指令编号、脚本开始标记、结束标记、ZEND VM指令、返回值、ZEND VM指令对应的参数
opcodes手册:
http://php.net/manual/en/internals2.opcodes.list.php
================如上为VLD输出的PHP代码生成的中间代码的信息,说明如下
Branch analysis from position 这条信息多在分析数组时使用。
Return found 是否返回,这个基本上有都有。
filename 分析的文件名
function name 函数名,针对每个函数VLD都会生成一段如上的独立的信息,这里显示当前函数的名称
number of ops 生成的操作数
compiled vars 编译期间的变量,这些变量是在PHP5后添加的,它是一个缓存优化。这样的变量在PHP源码中以IS_CV标记。
op list 生成的中间代码的变量列表
使用-dvld.active参数输出的是VLD默认设置,如果想看更加详细的内容。可以使用-dvld.verbosity参数。
php -dvld.active=1 -dvld.verbosity=3 demo.php
其中:
-dvld.verbosity=3是VLD在当前版本可以显示的最详细的信息
如果我们只是想要看输出的中间代码,并不想执行这段PHP代码,可以使用-dvld.execute=0来禁用代码的执行
php -dvld.active=1 -dvld.execute=0 demo.php
读源码要学会一种精神: 顺藤摸瓜
参考文档:
http://www.php-internals.com/book/?p=C-php-vld
http://www.php-internals.com/book/?p=chapt02/02-03-02-opcode
http://php.net/manual/zh/internals2.ze1.zendapi.php
http://www.laruence.com/2011/03/04/1894.html
http://blog.pureisle.net/archives/2294.html
http://www.imsiren.com/archives/704
http://blog.csdn.net/siren0203/article/details/8085813
http://www.cnblogs.com/miao-zp/p/6374311.html
本文转自cloves 51CTO博客,原文链接:http://blog.51cto.com/yeqing/1947654