当前位置: 首页 > 编程日记 > 正文

linux上使用strace查看C语言级别的php源码【一种方法】

如果你希望看到C语言级别的php代码就需要使用strace

这个默认是安装了的,如果没有安装可以

#yum install strace

查看httpd进程

#ps auxw | grep httpd

有多个,必须停止apache

[root@localhost usr]# /usr/local/webserver/apache2/bin/apachectl stop

启动单进程httpd
[root@localhost usr]# /usr/local/webserver/apache2/bin/apachectl -X -k start

再使用#ps auxw | grep httpd查看只有单经常,记下进程id

将strace绑定至apache

#strace -p 28224


算法

快速排序php代码

<?phpfunction quickSort($arr){$len    = count($arr);if($len <= 1) {return $arr;}$key = $arr[0];$left_arr    = array();$right_arr    = array();for($i=1; $i<$len; $i++){if($arr[$i] <= $key){$left_arr[] = $arr[$i];} else {$right_arr[] = $arr[$i];}}$left_arr    = quickSort($left_arr);$right_arr    = quickSort($right_arr);return array_merge($left_arr, array($key), $right_arr);}$arr = array(6,3,8,5,9,2,10);echo '<pre>';print_r(quickSort($arr));?>


在浏览器请求php页面,得到追踪信息


注意:如果看C语言生成的文件直接strace即可

#strace ./a.out


如果你只要看php的opcode可以参考:

PHP安装与使用VLD查看opcode代码【一种方法】


最简单的php代码

$a='123';   
echo $a;


追踪输出:


我们清晰的看到完整的解析流程

从eAccelerator中去读取缓存:

调用open()函数打开文件-->flock()函数锁定文件-->read()函数读取文件内容-->flock()解除锁定-->close()关闭文件

writev()输出http协议头http/1.1  200等等

关于eAccelerator参考 PHP安装eAccelerator

----------------------------------------------------

flock() 函数 锁定文件或解除锁定

定义:
int flock(int fd,int operation);
表头文件:
#include<sys/file.h>
说明:
flock()会依参数operation所指定的方式对参数fd所指的文件做各种锁定或解除锁定的动作。此函数只能锁定整个文件, 无法锁定文件的某一区域。
参数:
operation有下列四种情况:
LOCK_SH 建立共享锁定。多个进程可同时对同一个文件作共享锁定。
LOCK_EX 建立互斥锁定。一个文件同时只有一个互斥锁定。
LOCK_UN 解除文件锁定状态。
LOCK_NB 无法建立锁定时, 此操作可不被阻断, 马上返回进程。通常与LOCK_SH或LOCK_EX 做OR(|)组合。
单一文件无法同时建立共享锁定和互斥锁定, 而当使用dup()或fork()时文件描述词不会继承此种锁定。
返回值:
返回0表示成功, 若有错误则返回-1, 错误代码存于errno。
----------------------------------------------------------
静态HTML

我们请求一个html静态文件,追踪信息


可见直接是open()函数去读静态文件

==============================

                 linux函数分析查询工具

1.优先推荐linux 中man命令

2.一个不错的中文Linux手册:http://cpp.ezbty.org/manpage

3.在线查英文Man手册:

http://www.kernel.org/doc/man-pages/

http://man7.org/linux/man-pages/dir_all_alphabetic.html



http://linux.about.com/od/commands/l/blcmdl.htm

http://linux.die.net/man/

http://www.linuxmanpages.com/

==============================

通用函数

gettimeofday取得目前的时间

定义:
int gettimeofday ( struct timeval * tv , struct timezone * tz )
表头文件:
#include <sys/time.h>
#include <unistd.h>

gettimeofday()会把目前的时间有tv所指的结构返回, 当地时区的信息则放到tz所指的结构中。
timeval结构定义为:
struct timeval{
long tv_sec; /*秒*/
long tv_usec; /*微秒*/
};
timezone 结构定义为:
struct timezone{
int tz_minuteswest; /*和Greenwich 时间差了多少分钟*/
int tz_dsttime; /*日光节约时间的状态*/
};


#include<sys/time.h>
#include<unistd.h>
main(){struct timeval tv;struct timezone tz;gettimeofday (&tv , &tz);printf("tv_sec; %d\n", tv,.tv_sec) ;printf("tv_usec; %d\n",tv.tv_usec);printf("tz_minuteswest; %d\n", tz.tz_minuteswest);printf("tz_dsttime, %d\n",tz.tz_dsttime);
}

tv_sec: 974857339
tv_usec:136996
tz_minuteswest:-540
tz_dsttime:0

=======================================================================

poll 函数

http://linux.about.com/library/cmd/blcmdl2_poll.htm

Linux / Unix Command: poll

NAME

poll - wait for some event on a file descriptor

SYNOPSIS

#include <sys/poll.h>

int poll(struct pollfd *ufds, unsigned int nfds, int timeout);

DESCRIPTION

pollis a variation on the theme of select. It specifies an array of nfdsstructures of type
        struct pollfd {int fd;           /* file descriptor */short events;     /* requested events */short revents;    /* returned events */};
-------------------------

write 将数据写入已打开的文件内

定义:
ssize_t write (int fd,const void * buf,size_t count);
表头文件:
#include<unistd.h>
说明:
write()会把参数buf所指的内存写入count个字节到参数fd所指的文件内。当然, 文件读写位置也会随之移动。
------------------------------

Linux / Unix Command: writev

http://linux.about.com/library/cmd/blcmdl2_writev.htm

NAME

readv, writev - read or write a vector

SYNOPSIS

#include <sys/uio.h>

ssize_t readv(int fd, const struct iovec *vector, int count);
ssize_t writev(int
fd, const struct iovec *vector, int count);

struct iovec {void *iov_base;    /* Starting address */size_t iov_len;    /* Length in bytes  */
};
----------------------------

使用man命令查getsockname


其他函数:

ACCEPT()和ACCEPT4()

getuid  取得用户标识
getcwd  获取当前目录
rt_sigaction(2)  检查和改变信号动作,sigaction() 系统调用被用于更改一个进程在接收一个特定信号后的动作。
setitimer  获取设置定时器的值
poll(2) 在文件描述符上等待事件
stat64 获取文件状态
chdir  改变工作目录


相关文章:

iphone8p百度云认证_探秘百度数据工厂Pingo的多存储后端数据联合查询技术

作者介绍&#xff1a;张志宏&#xff0c;2013年加入百度大数据部&#xff0c;曾作为核心成员参与百度大数据平台的搭建。目前是百度数据工厂Pingo核心团队的技术负责人。Pingo是来自百度的离线大数据集成开发平台&#xff0c;使用Spark作为计算引擎&#xff0c;深度整合了资源调…

JavaScript文件中调用AngularJS内部方法或改变$scope变量

需要在其他JavaScript文件中调用AngularJS内部方法或改变$scope变量&#xff0c;同时还要保持双向数据绑定&#xff1b; 首先获取AngularJS application&#xff1a; 方法一&#xff1a;通过controller来获取app var appElement document.querySelector([ng-controllermainCon…

web类协议脚本-飞机订票系统示例

以下是LR自带的飞机订票系统的Demo&#xff0c;希望能帮助大家。 Action() {int iRand;int iTmp;char *strTmpA;char *strTmpB;char *strTmpC;char *position;if ((strTmpA (char *)malloc(100 * sizeof(char))) NULL) { lr_output_message ("Insufficient memory avail…

ACCEPT()和ACCEPT4()

ACCEPT章节&#xff1a;Linux 程序员手册 (2) 更新&#xff1a;2010-09-10到 易美翻译 翻译名字accept - 通过套接口接受一个连接 概要 #include Esys/types.h> /* 参看 “注意小节” */ #include Esys/socket.h>int accept(int sockfd, struct sockaddr *addr, socklen…

没有提示_华为手机发出莫名的提示音,打开什么也没有?原来是它们在作怪

不知道你们有没有遇到过这样的情况&#xff0c;在使用手机的过程中会出现一个非常奇怪的现象&#xff1a;当你听到手机发出声音&#xff0c;打开手机却发现什么通知也没有&#xff1f;这一度让我感到很困扰&#xff0c;本着“打破砂锅问到底”的精神&#xff0c;终于让我找到了…

近段时间佛我就偶尔无

jo建瓯市金佛玩手机欧力紧凑度 我株型紧凑我阿九倨傲四局李嘉诚转载于:https://juejin.im/post/5b8e5263e51d4538e2278c9b

php内核探索方法与资源

PHP内核探索 TIPI深入理解PHP内核 风雪之隅PHP源码分析 《php扩展开发及内核应用》 百度XLQ Gods blog codinglabsPHP内核探索&#xff1a;从SAPI接口开始PHP内核探索&#xff1a;一次请求的开始与结束PHP内核探索&#xff1a;一次请求生命周期PHP内核探索&#xff1a;单进程SA…

feign调用走不走网关全局拦截_feign服务端出异常客户端处理的方法

在使用feign进行远程方法调用时&#xff0c;如果远程服务端方法出现异常&#xff0c;客户端有时需要捕获&#xff0c;并且把异常信息返回给前端&#xff0c;而如果在开启熔断之后&#xff0c;这个异常会被消化&#xff0c;所以说&#xff0c;如果希望拿到服务端异常&#xff0c…

配置Cesium编译环境

1、安装node.js https://nodejs.org/en/ 2、配置node.js 在node.js安装目录下新建node_global、node_cache两个文件夹&#xff0c;并把node_global添加到环境变量 eg.D:\app\nodejs npm config set prefix D:\app\nodejs\node_global npm config set cache D:\app\nodejs\node_…

迷你世界电锯机器人_迷你世界:三分钟制作超简单飞翔石像机器人报道!

更多游戏资讯&#xff0c;请点击上方蓝字查询&#xff01;哈喽&#xff0c;大家好&#xff0c;还记得我之前分享的超简单的石像机器人吗&#xff1f;不记得了吗&#xff1f;我再帮助大家回忆回忆&#xff0c;之前研游酱分享的石像机器人总共是分两篇文章&#xff0c;一个是不会…

J2EE 第二阶段项目之编写代码(四)

我的任务就是项目统计。 1 效益统计 1 教育效益统计表 &#xff08;教育效益统计表&#xff0c;增,改&#xff0c;查看&#xff0c;查&#xff09; 2 农牧林效益统计表 &#xff08;农牧林效益统计表&#xff0c;增&#xff0c;改&#xff0c;查看&#xff0c;查&#xff09; 3…

PHP安装扩展mcrypt以及相关依赖项 【PHP安装PECL扩展的方法】

一&#xff1a;Mcrypt简介 Mcrypt是PHP的一个扩展&#xff0c;完成了常用加密算法的封装。其实该扩展是对mcrypt标准类库的封装&#xff0c;mcrypt完成了相当多的常用加密算法&#xff0c;如DES, TripleDES, Blowfish (default), 3-WAY, SAFER-SK64, SAFER-SK128, TWOFISH, TEA…

Javascript到PHP加密通讯的简单实现

互联网上大多数网站&#xff0c;用户的数据都是以明文形式直接提交到后端CGI&#xff0c;服务器之间的访问也大都是明文传输&#xff0c;这样可被一些别有用心之人通过一些手段监听到。对安全性要求较高的网站&#xff0c;比如银行和大型企业等都会使用HTTPS对通讯过程进行加密…

MYSQL添加新用户 MYSQL为用户创建数据库 MYSQL为新用户分配权限

2019独角兽企业重金招聘Python工程师标准>>> 1.新建用户 //登录MYSQL >mysql -u root -p >密码 //创建用户 mysql> insert into mysql.user&#xff08;Host,User,Password&#xff09; values&#xff08;‘localhost’&#xff0c;jeecn’&#xff0c;pa…

uml具有多种视图_UML建模与架构文档化

UML(统一建模语言) 是用元模型描述的&#xff0c;元模型是4层元模型体系结构模式中的一层。此模式的其他层次分别是元-元模型层、模型层和用户对象层。在原模型层&#xff0c;UML元模型 又被分解为三个子逻辑包&#xff1a;基础包(核心、扩展机制和数据模型)、行为元素包(描述模…

insert into与insert ignore以及replace into的区别

insert ignore表示&#xff0c;如果表中已经存在相同的记录&#xff0c;则忽略当前新数据&#xff1b; INSERT INTO有无数据都插入&#xff0c;如果主键则不插入; REPLACE INTO 如果是主键插入则会替换以前的数据; 例 1.insert语句一次可以插入多组值&#xff0c;每组值用一对…

德国SNS交友/视频网站Poppen.de的技术架构分享

Poppen.de是一个德国的 交友/ 聊天/ 视频 的SNS网站, 部分内容NSFW&#xff0c;网站采用了很多我们熟悉的技术&#xff0c;像Nginx &#xff0c;MySQL&#xff0c;CouchDB&#xff0c;Erlang&#xff0c;Memcached的&#xff0c;RabbitMQ(消息服务器)&#xff0c;采用了Graphit…

对数函数定义域和值域_呆哥数学每日一题 —— 复合函数值域

如果想要获取往期每日一题电子版&#xff0c;可以加我微信&#xff1a;daigemath366&#xff0c;备注&#xff1a;知乎 每日一题呆哥解析&#xff1a;这是一个函数和复合函数的综合问题首先我们先把原函数的值域求出来先直接求导&#xff1a;导数不容易判断单调性&#xff0c;我…

一些常用工具地址,随时更新中~

2019独角兽企业重金招聘Python工程师标准>>> 一些常用工具地址的备份&#xff1a; 一款比较全的先到化界面编辑器Neditor&#xff1a;https://gitee.com/notadd/neditor 前端ui组件库&#xff0c;类似element ui。iView&#xff1a;https://www.iviewui.com &#…

UNIX环境编程

linux函数分析查询工具1.优先推荐linux 中man命令2.一个不错的中文Linux手册&#xff1a;http://cpp.ezbty.org/manpage3.在线查英文Man手册&#xff1a;http://www.kernel.org/doc/man-pages/http://man7.org/linux/man-pages/dir_all_alphabetic.htmlhttp://linux.about.com/…

WCF优化的几个常规思路

前几天用WCF做项目时发现了一个效率问题&#xff0c;由于系统对效率要求较高&#xff0c;困扰了很长时间终于将问题解决了&#xff0c;写下来为以后的兄弟们参考&#xff0c;第一次写博客有不准确的地方还望同行们多喷多指点&#xff0c;先行谢过啦... 问题场景是这样的&#x…

使复选框选中_勾选复选框单元格变色,自动计数,在Excel中是如何实现的?

Excel中&#xff0c;我们经常会使用复选框来打勾打叉&#xff0c;这是复选框最基本的功能&#xff0c;相信很多小伙伴都会&#xff0c;但今天我跟大家分享的是复选框的其他操作技巧&#xff0c;勾选复选框变色&#xff0c;统计人数。下图中&#xff0c;我们要利用复选框是否打钩…

[短文速读] 重载有暗坑,JVM是如何执行方法的

前言 这将是一个系列文章。原因是自己写了很多文章&#xff0c;也看了很多文章。从最开始的仅仅充当学习笔记&#xff0c;到现在认认真真去写文章去分享。中间发现了很多事情&#xff0c;其中最大发现是&#xff1a;收藏不看&#xff01;总是想着先收藏以后有时间再看&#xff…

一笔画问题【数据结构-图论】

回家路上听到2个人在说&#xff1a;田字怎么一笔写成&#xff0c;并且笔划不重复。 田 我回家想了许久&#xff0c;觉得无论如何走正常的途径肯定是不行的&#xff0c;投机取巧脑筋急转弯的我不讨论。 那么是否可以找到数学定理&#xff1f; 其实就是欧拉七桥问题&#xff1a;1…

解析并符号 读取dll_Spring IOC容器之XmlBeanFactory启动流程分析和源码解析

一. 前言Spring容器主要分为两类BeanFactory和ApplicationContext,后者是基于前者的功能扩展&#xff0c;也就是一个基础容器和一个高级容器的区别。本篇就以BeanFactory基础容器接口的默认实现类XmlBeanFactory启动流程分析来入门Spring源码的学习。二. 概念要点1. 概念定义Be…

安装多个gcc

删除gcc #yum remove gcc 安装最新的 #yum install gcc 查找gcc源 可先通过“yum list compat-gcc*”查看版本&#xff0c;然后再利用“yum install compat-gccXXX”安装 #yum list compat-gcc* #sudo yum install compat-gcc-34.i686 查看gcc版本 #gcc -v #gcc34 -v参考&…

JAVA - HashMap和HashTable

1. HashMap 1) hashmap的数据结构 Hashmap本质就是一个数组&#xff0c;只是当key值重复时&#xff0c;使用链表的方式来存储重复的key值&#xff08;拉链法&#xff09;&#xff0c;注意&#xff1a;链表中存放的仍然是key值。如下图示&#xff1a; 当我们往hashmap中put元素…

empress和queen区别_queen与empress

(1)「queen」和「empress」不仅可以用来指称「king」和「emperor」的妻子&#xff0c;也能指代握有正式权力的女性君主。(2) 英国的君主(queen或king)之所以曾经有过empress或emperor的头衔&#xff0c;是因为英国曾统治过印度次大陆, 他们曾是印度的empress或emperor。如今&am…

在UIWindow上加类似于“回到顶部”的按钮

在公司上个版本的开发中遇到了一个UI布局的小问题&#xff1a; 某个页面需要增加一个分享按钮&#xff0c;但是该页面是二级页面&#xff0c;导航栏右边也已经放置了2个button。 起初和老大谈论这个问题的时候想到的方法是导航栏右边加三个button得了~但是一回想&#xff0c;这…

修改mysql 默认字符集 , 默认引擎

cd /var/lib/mysql/gamell vim db.optdefault-character-setutf8default-collationutf8_general_ciwq service mysqld restart或者service mysqld reload默认字符集修改完毕vim /etc/my.cnf[mysqld]datadir/var/lib/mysqlsocket/var/lib/mysql/mysql.sockusermysqldefault-stor…