Facebook 对 PHP 的改进
PHP 是传统意义上的解释型语言,而不是编译型语言。
因此,在命令行或 Web 服务器调用解释器解释 PHP 代码之前,PHP 代码就是 PHP 代码。PHP 解释器会解释 PHP 脚本,把代码转换为一系列 Zend 操作码(机器码指令,http://php.net/manual/internals2.opcodes.php),再把这些操作码交给 Zend Engine 执行。不过,解释型语言执行的速度比编译型语言慢很多,因为每次执行解释型语言编写的代码时都需要将其转换为机器码,消耗额外的系统资源。Facebook 意识到了这个性能瓶颈,与 2010 年开始开发一个叫 HPHPc 的编译器,把 PHP 代码编译成 C++ 代码。
HPHPc 编译器先把 PHP 代码编译成 C++ 代码,再把 C++ 代码编译成可执行文件,最后把这个可执行文件部署到生产服务器。HPHPc 基本上是成功的,它提升了 Facebook 的性能,降低了 Facebook 服务器 的负担。可是,HPHPc 对性能的提升已经到极限了,而且不能完全兼容 PHP 语言,还需要额外话时间编译,因此对开发者来说,反馈回路太长。Facebook 需要一种混合解决方案,既要进一步提升性能,又要让开发速度更快,省去编译代码的时间。
于是,Facebook 开始开发下一步 HPhpc,即 HHVM。HHVM 先把 PHP 代码转换成一种字节码中间格式,而且会缓存转换得到字节码,然后使用 JIT 编译器转换并优化缓存的字节码,将其变成 x86_64 机器码。HHVM 的 JIT 编译器提供了很多底层性能优化措施,这些优化措施是把 PHP 代码直接编译成 C++ 代码的 HPHPc 所不具备的。HHVM 才会及时把字节码编译成机器码,这一点和传统的解释型语言很像。2012年10约,HHVM 的性能超过了 HPHPc,而且仍在不断提升。
HHVM 的性能超越 HPHPc 之后不久,HPHPc 就被废弃了。现在,Facebook 的首选 PHP 解释器是 HHVM。
注意:
- HHVM 的实现可能很负责,可是说到底,HHVM 只不过是我们属性的 PHP 和 PHP-FPM 二进制文件的替代品:
- 我们在命令行使用 HHVM 二进制文件执行 PHP 脚本,就像 PHP 二进制文件一样。
- 我们使用 HHVM 二进制文件创建 FastCGI 服务器,就像 PHP-FPM 二进制文件一样。
- HHVM 原生执行很多常用的 PHP 扩展。
HVVM 适合我使用吗?
HVVM 并不是适合所有人使用。提升性能有更容易的方式,例如,减少 HTTP 请求数和优化数据库查询都是易于实现的方式,能显著提升应用的性能,减少响应时间。如果你还没使用这些优化措施,考虑使用 HHVM 之前先做这些优化吧。Facebook 的 HHVM 是为已经做了这些优化措施之后仍想进一步加速应用的开发者准备的。如果你觉得自己需要 HHVM,可以参考以下资源:
Facebook 对 PHP 的改进的更多相关文章
- Facebook工程师是如何改进他们Android客户端的
from://http://greenrobot.me/devnews/facebook-engineer-improve-android-app/ Facebook工程师是如何改进他们Android ...
- 【安卓开发】Facebook工程师是如何改进他们Android客户端的
原文出处: Facebook 译文出处:penkzhou 欢迎分享原创到伯乐头条 作为世界上最大的社交网络,Facebook的Android客户端面临着各种各样的使用环境(地理环境.Andro ...
- Hadoop的分布式架构改进与应用
1. 背景介绍 谈到分布式系统,就不得不提到Google的三驾马车:GFS[1],MapReduce[2]和BigTable[3]. 虽然Google没有开源这三个技术的实现源码,但是基于这三篇开源 ...
- HBase运维经验
http://www.qconbeijing.com/download/Nicolas.pdf 重点看了下facebook做了哪些改进以及他们的运维经验,比较重要的有以下几点: 改进: 1 加强了行级 ...
- 39、apk瘦身(转载)
本文转自::Android开发中文站 » 关于APK瘦身值得分享的一些经验 从APK的文件结构说起 APK在安装和更新之前都需要经过网络将其下载到手机,如果APK越大消耗的流量就会越多,特别是对于使用 ...
- Mcrouter-基于Memcached协议的缓存层流量管理工具(Memcached集群的另一个选择)(转)
Mcrouter 是一个基于Memcached协议的路由器,它是 Facebook缓存架构的核心组件,在峰值的时候,它能够处理每秒50亿次的请求.近日,Facebook开放了Mcrouter的源代码, ...
- Facebook对MySQL全表扫描性能的改进
原文博客如下: http://yoshinorimatsunobu.blogspot.com/2013/10/making-full-table-scan-10x-faster-in.html 如下是 ...
- [转]以Facebook为案例剖析科技公司应有的工具文化
原文:http://36kr.com/p/146507.html 这是一篇几年前的文章,但对于没有涉及到工具文化这个概念的人来说,还是很新的. 前言 前段时间和大众点评的 CEO 张涛聊天的时候碰到内 ...
- fackbook的Fresco (FaceBook推出的Android图片加载库-Fresco)
[Android开发经验]FaceBook推出的Android图片加载库-Fresco 欢迎关注ndroid-tech-frontier开源项目,定期翻译国外Android优质的技术.开源库.软件 ...
随机推荐
- 根据byte数组,生成文件
/** * 根据byte数组,生成文件 * filePath 文件路径 * fileName 文件名称(需要带后缀,如*.jpg.*.java.*.xml) */ public static void ...
- java计算两个经纬度之间的距离
/** * 计算点 是否在一个固定点的半径范围内 * @2016年10月20日 * @param a 经度1 已知 * @param b 纬度1 已知 * @param x 经度2 * @param ...
- 使用SikuliX定位Object(flash)元素
先说一下背景,这个是我们测试的系统上的一个上传文件的地方,但是用传统的selenium方法很难定位的到.具体的样子是下面这样的. 使用id等属性定位做点击操作好像不能直接操作.无奈之下,只好从网上找找 ...
- Makefile学习一
上次随着信号学习告一段落,也标志着linux系统编程相关的知识学完了,而学了这么多知识点,是需要用一个综合的项目来将其进行串起来的,这样学习的技术才会不那么空洞,所以接下来会以一个实际例子来综合运用下 ...
- Python 冒泡排序只适用位数相同,位数不同用a.sort()方法
数组内容双位数排序: #coding:utf-8 print u"中文" a = ['] b = 0 c = 0 print a i =0 for j in range (len( ...
- 在eclipse运行一个项目报端口被占的问题
1.端口被占问题解决方法. 我们运行javaweb项目的时候,如果不幸你的项目出现了上图的那种情况,不要慌,仅仅是端口被占了而已,只需要打开你tomcat里面的bin里面的shutdown.bat即可 ...
- hive函数之数学函数
hive函数之数学函数 round(double d)--返回double型d的近似值(四舍五入),返回bigint型: round(double d,int n)--返回保留double型d的n ...
- ldap系列-基础知识
来源:关键字排名 ldap 是什么? LDAP(Lightweight Directory Access Protocol)即轻量级目录访问协议,提供信息服务.那啥是目录服务呢? 目录服务是一种特殊的 ...
- learning java AWT 布局管理器FlowLayout
AWT提供了FlowLayout 从左到右排列所有组件,遇到边界就会折回下一行重新开始. import java.awt.*; public class FlowLayoutTest { publ ...
- Zabbix 邮件报警示例
Zabbix 邮件报警示例: 1.编辑 mail.rc 文件添加默认的邮箱配置 # vi /etc/mail.rc set from=1234567@qq.com set smtp=smtp.qq. ...