关于PHP7在手机微博服务端上的应用
订阅
首先上一张@Laruence 的靓照,表达一下对鸟哥的崇拜。大神收下我的膝盖吧。。。
我前两条关于php7性能测试数据的微博,乍一看只有个结果,给人感觉一头雾水。有人会说我写个简单的hello world页面,跑出来的数据比你这好看的多。确实如此,所以这就是我写这篇长文的原因。
好了,言归正传!!!
微博目前可以说是php最大的应用平台,尤其是在微博app的服务端。我在加入微博的时候,服务端还是apache+php的架构,单接口单机压测最大的qps也就200+(不知道这个数据说出来的时候我的脸。。。。。)。
2015年的夏天,那时候@Laruence 还是微博的总架构师,在他的带领下我们开始了微博app服务端的架构升级改造,这也是我第一次近距离观看大神,也是第一次和大神打下手。这一年我们风风火火的干了一票,当鸟哥的yaf框架上线后,我们的单接口qps到达500+,整体qps翻了3倍,最直接的效果是砍掉了40%的服务器(总qps就不说了,你们懂得),年末我们获得了百万霸道总裁奖。。。
逼逼叨叨说了这些,肯定有人烦了!说这些和PHP7有半毛关系,好吧!php7来了!
php7跳票了多次,终于在2015年12月3号发布了。我们在第一时间把微博app环境要用的包打出来并进行了功能和性能方面的测试。单独发一个php7的测试数据可能大家对性能的提升没有什么感觉和概念,但是有了上面的历史和下面的对比数据一下子就有变得意思了。
下面说一下相关的数据
压测的服务器硬件配置:
Intel(R) Xeon(R) CPU E5-2620 0 @ 2.00GH 内存16GB
PHP:
PHP 7.0.0 (cli) (built: Dec 8 2015 16:02:26) ( NTS )
Copyright (c) 1997-2015 The PHP Group
Zend Engine v3.0.0, Copyright (c) 1998-2015 Zend Technologies
with Zend OPcache v7.0.6-dev, Copyright (c) 1999-2015, by Zend Technologies
压测用例:feed接口。此接口是微博的主信息流,也是微博最具有价值的地方。改接口后方需要调用众多的第三方接口。接口最重、调用量也是最大的(对,没错,就是你天天刷的那个)
测试工具:http_load
压测试结果对比:
这个是现在线上跑的php5.4.11的压测数据
这个是php7的压测数据
看到这个数据以后,我写准备第一条微博,但是写了一半不敢发出去,主要的原因是那会我还接受不了这个数据给我带来的震撼。
对比php5.4,php7的单接口qps提升了93%。(由于php7在内存方面有较大优化,同样配置的服务器进程数要比php5.4多开140个)
当开启hugepage这个新特性后,qps较开启之前性能又有20%提升
php7 with hugepage
看完后是不是有种迫不及待要升级的冲动。赶紧动起来吧,要知道版本升级后今年的kpi就完成了。不管你们升级不升级,我们是要指着这个过今年的三节,原因你懂得。。
提醒一下:用到yaconf这个神器的朋友,去@Laruence 的代码仓库更新到最新版本
当然在做这个新环境的时候遇到一些坑,多亏有@苏湳_ 在一旁默默的调试着,一起批心带月的赶末班地铁。。
好吧,就先写这些吧!欢迎各位拿板砖拍我吧!