Linux.中国 - 开源社区

 找回密码
 骑士注册

QQ登录

微博登录


写在 PHP7 发布之际一些话

做开源也有4,5年的时间了, 从最初的 Yaf, 到今天的 PHP7, 我参与的项目越来越多, 使用我代码的用户也越来越多。明天就要发布的 PHP7, 绝对是我从事开源以来的一个最重要里程碑。我应该纪念一下今天, 就让我稍微感性一次吧。

PHP7 项目开始于去年春节的时候, 那个时候我们基于 PHP-5.5 的 Opcache JIT 项目基本上因为无法得到期望的结果而搁置了。一些在做 JIT 的时候收集到的信息让我们认识到, 基础部分还不够好, 并不能很好的支持 JIT, 所以在2014年2月左右吧, 我们开始了重构项目。当时的希望是说通过重构, 能得到30%以上的性提升, 为将来的进一步优化提供基础。

那时还没有给这个项目起名字, 我们只是试试。那几个月是我最忙碌的时刻, 因为只有我们俩个人在这个项目中, 我还因为自身微博的工作也比较忙, 所以基本上只晚上的时间都扑在了上面。 不过好在, 我和另外一个人有5个小时的时差, 所以很多工作可以串行起来。

随着项目的推进, 我们惊喜的发现性能提升比我们想象的还要大。到4月的时候另外一个人也加入了进来, 到5月基本上已经完成了大部分的工作, 于是我们公布了这一个成果, 定名为 PHP NG 项目。

但我没想到的是, 我们遇到了社区很大的阻力, 因为在我们秘密开发 PHP NG 的时候, 社区还并行着一个主要是微软的同学们发起的64位支持的项目。当我们公开 PHP NG 的时候, 他们质疑说, 突然拿着这么大的一个 Patch 出来, 没有其他人懂, 后续如何维护, 如何和64位支持的分支合并等, 继而反对采纳 PHP NG 分支。 当时我是非常沮丧的, 持续好久的争吵也让我感到非常疲倦, 最后因为我实在无法排遣, 一腔怒火的也不管自己蹩脚的英文, 在邮件组回了一封吐槽邮件, 呼吁大家珍惜这个性能提升分支。

还有个很好玩的插曲, PHP NG 的支持者很多, 他们也对这样的争吵很郁闷。某天, 有一些支持者就在 PHP 官网上发布了这样的一个新闻, 其中写到:

"When we aren't looking for pictures of kittens on the internet, internals developers are nearly always looking for ways to improve PHP, a few developers have a focus on performance。",

但当天反对者们就说, 不行, PHP NG 还没有被接纳, 要求删除这篇文章。好在考虑到文章已经发出去了, 最后就在首页上下掉了这个文章的入口, 只是在存档中保留了内容。 很多媒体都感受到了这次的乌龙。

争执不下之后, 不得已, 我们只能发起投票, 来决定是否接纳 PHP NG。好在, 最后投票的时候, 绝大部分人都支持了 PHP NG 项目, 并决定以 PHP NG 为基础, 开始我们的新版的 PHP 的开发。 当时还没有确定用 PHP6 还是 PHP7 版本号(后来投票决定PHP7)。 我现在经常会说这次经历, 让我感受到了"民主之痛"。

之后的事情大家就都能看到了, 在这近两年的时间里, 各种新特性的加入, 性能的持续提升, 很多以前不合理的地方改进等等, 都加入到了 PHP7, 让 PHP7 越来越丰满。 从最底层的 ZVAL 的改变, 到标量类型提示, 从最初的30%的性能提升, 到现在超过100%的性能飞跃, 每一处变化都让人值得期待。 然后经过几次不情愿的跳票, 终于, 到今天, 这一切都将呈现于你面前。

有的时候我会想, 我是幸运的, 幸运在一直有机会做没做过并且有挑战的事情, 幸运在一直能感受到自己的成长, 幸运在所做的大部分努力, 终究看到了效果, 得到了回报。 也衷心的希望我的幸运可以激励更多的人参与到开源中来。

未来, 我们还会一如既往的致力于提升 PHP 的性能, 提升 PHP 的品质, 让更多的 PHPer 们, 可以持续享受到透明的提升。

最后, 做开源这么久, 带给了我很多的收获, 我要谢谢大家, 谢谢这些鼓励, 也谢谢那些善意的谬赞。

PS: 本来想等到 PHP7 发布以后再发的, 但是想到可以为它的到来造势, 就先发布罢。 PHP7 目前已经可以下载, 官方的宣告考虑到时差问题, 后天早上来再看吧。 目前下载地址:  http://php.net/get/php-7.0.0.tar.gz/from/a/mirror 

enjoy!

谢谢

发表评论


最新评论

我也要发表评论

返回顶部

分享到微信朋友圈

打开微信,点击底部的“发现”,
使用“扫一扫”将网页分享至朋友圈。