您好,欢迎访问一九零五行业门户网

PHP扩展——C扩展实现滚动记录日志

前言万事开头难,没错就是这样!!
在没有真正开发php扩展之前,一直觉得php扩展开发对我来说是一个很遥远的事情,虽然自己有些c\c++基础,但是看php源码的时候还是很吃力,现在看来主要还是没有下决心搞这个,这次终于下决心搞一个php扩展类库,搞了一个周末,终于把之前的一个写日志的类库封装为php扩展的形式了,这也算是开发php扩展入门了,这里跟大家分享分享,这个是源代码:一个单例模式的记录日志的php扩展
开发我开发的是一个php扩展的形式进行日志记录,功能和前几天的php滚动日志基本一致,也是单例模式运行。
记录下开发中要注意的几点:
这里只是很少一部分,具体的可以看我的源代码,我觉得最好的学习方式就是看源码了,遇到不会的不懂得自己去查,记忆更深刻.
了解zval结构,zval是php内核中定义的数据结构//定义在zend/zend_types.h:55 和 zend/zend.h:322行typedef struct _zval_struct zval;struct _zval_struct { /* variable information */ zvalue_value value; /* value */ zend_uint refcount; zend_uchar type; /* active type */ zend_uchar is_ref;};typedef union _zvalue_value { long lval; /* long value */ double dval; /* double value */ struct { char *val; int len; } str; hashtable *ht; /* hash table value */ zend_object_value obj;} zvalue_value;//其中的zval.type表示变量的类型,基本类型有下面几种,定义在zend/zend.h:583中#define is_null 0#define is_long 1#define is_double 2#define is_bool 3#define is_array 4#define is_object 5#define is_string 6//部分常用的zval相关函数或者宏,定义在zend/zend_operators.h:441行z_lval_p(zval_p) //获取zval_p指针所指向的zval结构的值,值得类型为longz_strval_p(zval_p)
如何传参给函数php扩展中接受参数的时候通过函数zend_parse_parameters,类似下面的形式进行传参:zend_parse_parameters(zend_num_args() tsrmls_cc, s, &msg, &msg_len);第二个参数是要传入参数类型的列表,有下面规范
从php5.3开始, zend_parse_paramters_函数新增了如下几个新的类型描述符:f - function or array containing php method call info (returned as zend_fcall_info and zend_fcall_info_cache)h - array or hash_of(object) (returned as hashtable)l - long, limits out-of-range numbers to long_max/long_min (long)z - the actual zval (zval**)
开发面类库的时候常用的一些函数zend_declare_property_null(mylogs_ce, zend_strl(level), zend_acc_private tsrmls_cc); //类似上面的函数是类进行初始化的时候设置变量zend_declare_class_constant_long(mylogs_ce, zend_strl(log_debug), 0 tsrmls_cc);//类似上面的函数是类型进行初始化的时候设置常量zend_read_property(mylogs_ce, instance, zend_strl(level), 0 tsrmls_cc);//上面的是从实例instance中读取变量的值zend_hash_find(&ce->constants_table, zend_strs(log_debug), (void **)&_level);//上面的是从mylogs_ce这个类中读取常量zend_update_property_long(mylogs_ce, instance, zend_strl(level), level tsrmls_cc);//上面的是从instance中读取变量level
注意注意内存的释放,防止内存泄漏,我在开发完成之后,发现存在内存泄漏情况,可以利用valgrind查看内存泄漏情况,对不再需要的内存即使进行释放,不然有可能在大量循环处理的时候出现内存占用过多,从而导致报错。
还有就是多看看例子,鸟哥的yaf源码可以多参考参考,这个帮了我很多,学习的初期就是“照猫画虎”。看看效果开发完成之后,写了个脚本试了下,循环输出日志10w次(准确的说是30w,debug、msg、err各10w次),下面是环境和结果
环境:
centos虚拟机,64位内存 1gcpu i5-2410m @ 2.30ghz #这个获取到的是我电脑的
次数php代码php扩展
第一次 8.83s 6.13s
第二次 8.60s 6.14s
平均 8.72s 6.14s
可以看到使用php扩展的方式速度可以提升原来的1/4左右,哈哈,还不错,我的代码可能还有很大的优化空间,加油努力~~
我将所有的代码放在了github上:
一个单例模式的记录日志的php扩展
参考文章用c/c++扩展你的php —— laruence
深入php变量存储结构 —— 文大侠
5/24/2015 3:10:45 pm
本文版权归作者iforever(luluyrt@163.com)所有,未经作者本人同意禁止任何形式的转载,转载文章之后必须在文章页面明显位置给出作者和原文连接,否则保留追究法律责任的权利。
以上就介绍了php扩展——c扩展实现滚动记录日志,包括了方面的内容,希望对php教程有兴趣的朋友有所帮助。
其它类似信息

推荐信息