文档章节

利用PHP的VLD查询OPCODE

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

为了能更好的查看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
博文 78
码字总数 59637
作品 0
郑州
高级程序员
PHP性能优化工具--vld

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

孤独求学人 ⋅ 2016/12/25 ⋅ 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 ⋅ 2

opd-山寨版vld

起因 很久以前(大概1年多了)看到鸟哥的《使用PHP Embed SAPI实现Opcodes查看器》,然后在Ubuntu上跟着折腾了起来,最后勉强也是跑起来了。最近找回了这份代码,打算在新笔记本上编译,然后...

solu ⋅ 2014/02/18 ⋅ 0

PHP 性能分析与实验——性能的宏观分析

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

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

PHP 性能分析与实验——性能的宏观分析

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

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

从汇编看for和while循环的效率

这事情得从C语言开始说起,先编写下面这两段代码: 1、 #include<stdio.h> int main(void) { int i; for(i = 0; i < 10; i++) { } return 0;} 2、 #include<stdio.h> int main(void) { int i......

firebroo ⋅ 2015/04/25 ⋅ 3

分析PHP内核中是如何实现 empty, isset 这些函数的

叨叨几句 本来这个问题是在oschina上提出的: 但一直没收到合适的答案,所以还是自己下功夫梳理了一下,如果有错误的地方,欢迎交流。 通常的函数是通过ZEND_FUNCTION(xxx) 这种宏定义来实现...

扣丁禅师 ⋅ 2015/11/07 ⋅ 1

PHP内核中是如何实现 empty, isset 这些函数的?

$TOC$ 叨叨几句 本来这个问题是在oschina上提出的: 但一直没收到合适的答案,所以还是自己下功夫梳理了一下,如果有错误的地方,欢迎交流。 通常的函数是通过ZEND_FUNCTION(xxx) 这种宏定义...

踏雪秋菊 ⋅ 2016/08/22 ⋅ 0

深入浅出PHP(Exploring PHP)

一直以来,横观国内的PHP现状,很少有专门介绍PHP内部机制的书。呵呵,我会随时记录下研究的心得,有机会的时候,汇总成书。:) 今天这篇,我内心是想打算做为一个导论: PHP是一个被广泛应用...

晨曦之光 ⋅ 2012/03/09 ⋅ 0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

zblog2.3版本的asp系统是否可以超越卢松松博客的流量[图]

最近访问zblog官网,发现zlbog-asp2.3版本已经进入测试阶段了,虽然正式版还没有发布,想必也不久了。那么作为aps纵横江湖十多年的今天,blog2.2版本应该已经成熟了,为什么还要发布这个2.3...

原创小博客 ⋅ 49分钟前 ⋅ 0

聊聊spring cloud的HystrixCircuitBreakerConfiguration

序 本文主要研究一下spring cloud的HystrixCircuitBreakerConfiguration HystrixCircuitBreakerConfiguration spring-cloud-netflix-core-2.0.0.RELEASE-sources.jar!/org/springframework/......

go4it ⋅ 今天 ⋅ 0

二分查找

二分查找,也称折半查找、二分搜索,是一种在有序数组中查找某一特定元素的搜索算法。搜素过程从数组的中间元素开始,如果中间元素正好是要查找的元素,则搜素过程结束;如果某一特定元素大于...

人觉非常君 ⋅ 今天 ⋅ 0

VS中使用X64汇编

需要注意的是,在X86项目中,可以使用__asm{}来嵌入汇编代码,但是在X64项目中,再也不能使用__asm{}来编写嵌入式汇编程序了,必须使用专门的.asm汇编文件来编写相应的汇编代码,然后在其它地...

simpower ⋅ 今天 ⋅ 0

ThreadPoolExecutor

ThreadPoolExecutor public ThreadPoolExecutor(int corePoolSize, int maximumPoolSize, long keepAliveTime, ......

4rnold ⋅ 昨天 ⋅ 0

Java正无穷大、负无穷大以及NaN

问题来源:用Java代码写了一个计算公式,包含除法和对数和取反,在页面上出现了-infinity,不知道这是什么问题,网上找答案才明白意思是负的无穷大。 思考:为什么会出现这种情况呢?这是哪里...

young_chen ⋅ 昨天 ⋅ 0

前台对中文编码,后台解码

前台:encodeURI(sbzt) 后台:String param = URLDecoder.decode(sbzt,"UTF-8");

west_coast ⋅ 昨天 ⋅ 0

实验楼—MySQL基础课程-挑战3实验报告

按照文档要求创建数据库 sudo sercice mysql startwget http://labfile.oss.aliyuncs.com/courses/9/createdb2.sqlvim /home/shiyanlou/createdb2.sql#查看下数据库代码 代码创建了grade......

zhangjin7 ⋅ 昨天 ⋅ 0

一起读书《深入浅出nodejs》-node模块机制

node 模块机制 前言 说到node,就不免得提到JavaScript。JavaScript自诞生以来,经历了工具类库、组件库、前端框架、前端应用的变迁。通过无数开发人员的努力,JavaScript不断被类聚和抽象,...

小草先森 ⋅ 昨天 ⋅ 0

Java桌球小游戏

其实算不上一个游戏,就是两张图片,不停的重画,改变ball图片的位置。一个左右直线碰撞的,一个有角度碰撞的。 左右直线碰撞 package com.bjsxt.test;import javax.swing.*;import j...

森林之下 ⋅ 昨天 ⋅ 0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部