最近,在团队的努力下,我们将全体 Web 做事器从 PHP 5 升级到 PHP 7,全体升级过程非常故意思,因此通过本文分享如下。

升级的过程

这统统都开始于 2015 年秋日一个 hackday 项目。
@oli 和 @trav 在 Tumblr 运行一个 PHP 7 rc 版本。
在那时候,很多 PHP 扩展都还不支持PHP 7,但有非官方的分支担保实验性支持。
只管这样,Tumblr 已经可以运行在 PHP7 上了!

php移植又一个进级到PHP 7后机能晋升50的案例Tumblr AJAX

今年春天,Tumblr 可以更加稳定的运行在 PHP7 上,我们决定开始升级。
我们做的第一件事是打包新版本,以便更随意马虎安装并担保同等。
与此同时,我们将内部 PHP 扩展移植到新版本,以是统统都准备好了。

我们编写了一个可以升级(或降级)做事器的小脚本。
然后,在春季及夏季,一贯都在运行测试并进行性能监测和评估。
随着韶光推移,我们开始在更多开拓职员日常利用的机器里运行PHP 7。

末了,在 8 月尾,我们对测试结果感到满意,于是将 PHP 7 更换到我们一小部分生产做事器。
两个星期后,所有线上做事器都已更新到 PHP7。

测试与持续集成

当进行这样的升级时,用测试以确保代码精确运行是非常主要的,我们有几个方法。

在这个项目中,我们利用 Phan 探求代码库中与 PHP 7 不兼容的代码。

Phan:https://github.com/etsy/phan

我们还有一套单元和集成测试,帮助我们识别有问题的模块。
由于项目开拓还在进行中,我们须要确保没有添加 PHP7 不兼容的新代码,以是我们设置了持续集成的任务,同时在 PHP5 和 PHP7 环境下运行所有测试。

升级结果

终极的结果是什么? 性能和措辞特性对我们来说是最主要的两个结果。

性能

当我们在第一批做事器上运行 PHP7 时,我们非常密切地关注各种性能监控图表,以确保运行顺利。
正如我们上面提到的,我们正在进行性能改进,实际上的升级结果是非常惊人的, 延迟减少一半,并且做事器上的 CPU 负载降落了 50% 或者更多。
不但页面相应速率提高了一倍,而且只利用了一半的 CPU 资源。

这些是来自我们的API做事器的图。
如您所见,延迟低落到不到一半,峰值负载均匀值现在低于之前的最低点!

措辞特性

除此之外,PHP 7 也带来了很多有趣的新功能。
一些亮点是:

标量类型提示:PHP 历史版本在类型安全方面相称差,PHP 7 引入标量类型提示(Scalar type),确保通报的值符合特定类型(字符串,bool,int,float等)。

返回类型声明:现在,利用 PHP 7,函数可以有显式返回类型。
这减少了对样板代码和手动检讨函数返回值的需求。

匿名类:与匿名函数(闭包)非常类似,匿名类在运行时构建,可以仿照类/接口乃至扩展其他类。
这些对付像日志类这样的实用工具非常有用,并且在单元测试中非常有用。

各种安全和性能增强。

总结

PHP7 相称棒。

以下是国外网站一些网友评论。

jsjohnst :

我没有参与这个升级过程,但在基于我对 Tumblr(过去在那里事情了 3 年)代码库的理解,以及个人对 PHP 的背景(一贯是 PHP 贡献者〜13 年),性能提升有 95% 的可能性与 PHP7 干系。
Chorus (Tumblr 内部基于的框架)中利用的许多模式和在代码库,都会在 PHP7 内部的变革中受益匪浅。

tyingq:

从 PHP5.x 切换到 PHP7 时,在相应韶光,TPS 和内存利用方面的显著改进

https://www.symfony.fi/entry/symfony-benchmarks-php-56-hhvm-and-php-7

uses:

我们利用的 PaaS 云平台最近升级了一个 PHP 7。

对付运行 Bolt 的网站(一个PHP CMS,它大量利用自动加载类),我们看到性能提高了 45% ~ 55%。
对付 Wordpress,它是约 30 ~ 40%。

bkanber :

我以为也可能是由于 PHP7 默认启用了 opcache,而之前并没有启用。

也便是说,更快的解析器和 intepreter 也会做更快的自动加载,以是纵然不是opcache,也可能是凭债主动加载类被阐明得更快。

nikic:

我们在 7.1 版中 perf 显示在实际运用中没有看到显著的收益(对打算密集型代码有一些改进,比如循环中的打算)。

JIT 是否会对运用程序带来重大改进尚不清楚,我们希望如此。

boulos:

对,我良久以前也比拟过,大多数的性能改进来自于运行时的 C 代码改进,比如在实际运行的系统中,产生较少的字符串副本非常关键。
这是你在 PHP 7 改进中首先看到的。

利用 PHP 从字节码阐明器天生 x86 机器码将意味着在你不绝止“跳出”的地方,你该当看到更靠近 C 代码性能(JavaScript,Python 等同样如此)。
PHP7 的标量类型提示和其他一些小调度(故意义的)该当使 jit 编程一个更随意马虎的任务(比拟从 PHP 5.4 到 PHP7)。
类型推理是非常有效的,在实践中(见Paul Biggar对此的精良论文),在 PHP 程序中确实没有那么多的多态性。
函数的参数常日有一个或两个类型,或者它们实际上是多态的并有跟多的变体。

progforlyfe

没错,最大的性能改进是来自类似 JIT 改进, 跟 HHVM 所做的事情类似。

tiffanyh:

我很困惑,PHP 7 现在没有 JIT,但它的性能已经与 HHVM(它有JIT)同等。

然后便是说 PHP 8(与JIT)将显著快于 HHVM?

TazeTSchnitzel :

未必,这可能意味着很多 HHVM 的性能改进与 JIT 无关。

英文原文:

https://engineering.tumblr.com/post/152998126990/php-7-at-tumblr

评论来源

https://news.ycombinator.com/item?id=12921570

高可用架构

改变互联网的构建办法

长按二维码 关注「高可用架构」公众年夜众号

高可用架构主理 GIAC 环球互联网架构大会特殊推出编程措辞与架构专题,议题方向聚焦在互联网架构中如何精确的引入 Python,Go,Java,Rust 等热点措辞。
在 11 月购买还可以享受 7 折早鸟票,双日套票最低仅需 1,260 元,点击阅读原文进入购买页面。