PHP 5.3新版特性分析

2009-09-04 10:21:59 作者:admin 来源: 浏览次数:0 网友评论 0

从php4到php5,从个人框架到开源框架的发展,见证着php从山寨走上正规大军的发展。php6还在酝酿中,相信php5会作为php6小试牛刀的场地。php5.3是php5的一个里程碑,加入了大量新特性。

  我个人总感觉php功能是越来越多了,但是php的语法却越来越丑陋了,有时加入了新功能,而新功能带来了问题,为了修复问题,又要加入新的语法来修复,郁闷。估计php用语法修复问题是为了更好的解析。

  一、mysql驱动mysqlnd

  一直以来,php都是通过mysql客户端连接mysql,而现在mysql官方已经推出php版的mysql客户端,而这个mysqlnd有效降低内存的使用以及提高性能。具体可以看:

  http://dev.mysql.com/downloads/connector/php-mysqlnd/

  http://forge.mysql.com/wiki/PHP_MYSQLND



  从图中可以看出,使用mysqlnd少了从mysql驱动中复制数据到php扩展这一步。mysqlnd使用copy-on-write,也就是写时复制,读引用。

  mysqlnd已经内置在php5.3的源码中,编译的时候使用--with-mysql=mysqlnd、--with-mysqli=mysqlnd 和 --with-pdo-mysql=mysqlnd 安装mysqlnd驱动。

  mysqlnd的优点

  编译php更方便了,不需要libmysql,已经内置在源码中

  编译php更方便了,不需要libmysql,已经内置在源码中

  使用php许可,避免版权问题

  使用php的内存管理,支持php内存限制(memory_limit)

所有数据在内存只有一份,之前的libmysql有两份,参考上图

  提供性能统计功能,帮助分析瓶颈

  mysqli支持长连接(persistent connections)

  性能绝对比libmysql要快

  在驱动层增加缓存机制

  看了这么多特点,有点矛盾,作为数据库抽象层的PDO能把不同后端的特点发挥出来吗?如果使用mysql作为数据库的话mysqli是不是更好的选择?我总觉得mysqli只是个过度产品,PDO才是未来的。

  二、性能提高

  md5()大概提高了10%-15%的性能

  Better stack implementation in the engine,没明白

  常量保存在ROM里(Constants moved to read-only memory),这里没明白意思

  改进异常处理,操作码(opcode)更简洁

  解决了include(require)_once重复打开的问题,之前once我都是用静态变量实现的,终于解决这个问题了

  用gcc4编译的二进制文件将更小

  整体性能提高了5%-15%

0
顶一下
0
踩一下

[错误报告] [推荐] [收藏] [打印] [关闭] [返回顶部]

最新图片文章

最新文章

视频新闻