频道栏目
首页 > 资讯 > 错误报告 > 正文

PHP OceanBase扩展:错误日志的优化

16-01-07        来源:[db:作者]  
收藏   我要投稿

Oceanbase,一个分布式数据库

一个支持海量数据的高性能分布式数据库系统,实现了数千亿条记录、数百TB数据上的跨行跨表事务,由淘宝核心系统研发部、运维、DBA、广告、应用研发等部门共同完成.

目前OceanBase已经应用于淘宝收藏夹,用于存储淘宝用户收藏条目和具体的商品、店铺信息,每天支持4~5千万的更新操作。等待上线的应用还包括CTU、SNS等,每天更新超过20亿,更新数据量超过2.5TB,并会逐步在淘宝内部推广.

OceanBase 数据库支持多种客户端,C++/JAVA,我负责的收藏夹功能就是用的OceanBase数据库作为存储,刚开始的时候接手不顺利,Ob从来没用过,而Ob又不完全相同于其他类型的Nosql,所以开始有些困难,不过用到现在,确实还不错,只是PHP的客户端用起来很坑爹。

php的客户端用的是C做的扩展,虽然能够实现读写更新等操作,但是对于排错来讲,那基本就是个零,无论你调用成功还是失败,永远只返回true和false,怎么失败的都不知道。

早就说要改一改,能够让排错能力更强一些,前两天终于能够抽出点时间,来修改一下扩展。

两种方案:
1、提供getError和getErrno方法用于获取ob的错误记录。
2、直接将错误日志打印到php.ini配置的log_file,可以用log_level来设置错误级别:支持,ERROR,WARN,INFO,DEBUG ,日志级别后面越来越高。

最后决定采用第二种方案。

没有什么难度,只是根据php.ini的配置调用libobapi.cpp的 ob_api_debug_log API,

ob_api_debug_log(obj->ob,OCEANBASE_G(log_level),OCEANBASE_G(log_file));

使用方法:

1
2
3
4
5
6
7
[oceanbase]
extension=oceanbase.so ;加载扩展
;You Can use theses Args:"ERROR","WARN","INFO","DEBUG"
;@siren
oceanbase.log_level = ERROR;设置错误级别
 
oceanbase.log_file=/tmp/ob_log_2.txt;设置发生错误时的日志文件。

源码已经放在github中。。

相关TAG标签
上一篇:PHP基本语法第三章-流程控制
下一篇:htaccess规则要如何写呢?请在?号处填写内容。多谢(急)
相关文章
图文推荐

关于我们 | 联系我们 | 广告服务 | 投资合作 | 版权申明 | 在线帮助 | 网站地图 | 作品发布 | Vip技术培训 | 举报中心

版权所有: 红黑联盟--致力于做实用的IT技术学习网站