經過10年的漫長等待,PHP 7終於正式問世了。這個影響全球8成網站的開發語言,一舉從5.0版,跳過了功敗垂成的6.0版,一舉進入了7.0時代。

20年前初夏,1995年6月8日,一位愛解決問題的C語言軟體工程師,苦於不知如何用C來做一個自己的個人首頁,因為沒人提供C語言版的網頁開發環境。他索性自己來寫一個,並命名為Personal Home Page Tools,簡稱PHP Tool。這就是日後用來開發出Facebook、Yahoo等全球2億多個網站的PHP語言最初的版本。而這位C語言開發者Rasmus Lerdorf,也就成了PHP之父。PHP隨著網際網路從1996年開始起飛,也迅速成為開發人員打造網站的首選技術。

不過,在快速進化的IT世界中,越早出現的技術,往往也背負了越重的轉型包袱。PHP語言一路跟著作業系統,從32位元架構開始跨入64位元,在2004年推出的PHP 5更是一個體質大改造的版本,順利地跨入了物件導向架構的世界,穩坐網站開發技術龍頭。即使微軟打著容易上手為號召,以ASP網站開發技術搶攻市場,PHP仍是許多網站開發者心目中的首選。2008年時,光在臺灣,每4個網站,至少有1個是採用PHP開發。

不過,2005年時, PHP在Unicode的支援過程上,重重摔了一跤。Unicode支援原本要成為PHP 6的主打特色,但在開發社群中對多國語言支援的爭論,和PHP效能議題的質疑,衍生出了漫長的拉扯論戰,也延宕了PHP 6的發展,甚至PHP 5.3的小改版都搶先在2009年支援了PHP 6的大部分功能(除了Unicode支援外),隔年春天,PHP 6計畫正式宣告失敗而終止,也讓PHP技術的發展,蒙上了一層陰霾。PHP 5持續改版推陳出新,但總是處於一種小改小修的優化,而鮮有從根本上革新的大進步。儘管語言進展緩慢,但PHP的影響力卻是持續不墜,甚至越來越大,2013年初,Netcraft網站統計,全球超過2.4億個網站後端開發語言使用的就是PHP。

Rasmus Lerdorf今年5月來臺演講時告訴我,Facebook為了自家網站速度而重新改寫了PHP編譯引擎的JIT作法,引起了PHP開發者對於PHP語言效能的再思考。

2014年,開始有一群PHP開發者(包括了來自中國的惠新宸)展開PHP語言的重構,也就是PHP NG專案(PHP New Generation),為了提高效能,他們不惜重新檢視甚至改寫PHP語言原始碼,一試結果發現,PHP程式的效能大幅提升了30%。

舊版PHP語言的發展目標是希望盡可能地提供更多功能,來滿足任何網站開發的需求,但新的PHP 7,則是希望兼顧效能和功能。Rasmus Lerdorf這樣說。

但要對一個已經發展了10年,歷經了全球開源開發人員精心雕琢之後的開發語言,還想要找出很大效能突破的關鍵,不是一件容易的事。

也因此,PHP 5重構專案PHP NG的巨大成效,也獲得PHP開發社群支持,成了PHP 7的基礎,開發社群轉而細細地推敲每一行PHP程式碼,想辦法從各種地方找出效能優化的關鍵。

例如PHP核心開發團隊花了很多心力來縮減PHP程式執行時所需搬動的記憶體位元數,像是將PHP儲存變數的資料架構zval從24位元縮減至16位元。或是重新檢視CPU層級的程式碼運作過程,來確保PHP 7程式碼更能符合新一代的處理器架構。

每一次修改的優化可能只改善不到0.5%的效能,但經過了數百次如此這樣斟酌推敲的成果,就讓PHP 7的效能比舊版提高了一倍。

儘管從PHP 5升級到7也不是一件容易的事,但對全球2億個用PHP開發的網站而言,PHP 7無疑是一個解決既有網站效能瓶頸的新救星。

PHP 7問世,2億網站效能翻倍有望的更多相关文章

  1. 在Windows驗證網站設定部分匿名存取

    最近接連遇到幾次的需求:供內部使用的ASP.NET網站,全站使用Windows驗證,使用者以網域AD帳號登入,但網站包含少數API性質的ASHX.ASPX或MVC Action,提供其他系統呼叫整合. ...

  2. UVa Online Judge 工具網站

    UVa Online Judge 工具網站   UVa中译题uHuntAlgorithmist Lucky貓的ACM園地,Lucky貓的 ACM 中譯題目 Mirror UVa Online Judg ...

  3. 網站SSL加密原理簡介(2张图,握手有9个步骤,解释的很清楚)

    Secure Socket Layer說明 SSL是Secure Socket Layer(安全套接層協議)的縮寫,可以在Internet上提供秘密性傳輸.最早是Netscape公司所提出,SSL的目 ...

  4. [SharePoint 2010] 如何在小組網站內頁面上撥放影片或是音效檔

    在SharePoint 2010中, 我們可以像是Youtube一樣在網頁上撥放影片或是音效檔案. 影片或音效是採取串流的方式來撥放. 也就是說我們不需要把整個檔案都下載回來才開始撥放. 點選沒多久我 ...

  5. [SharePoint 2010] 如何安裝啟用多國語系支援的SharePoint網站

    SharePoint 2010的多國語系支援與前一版的SharePoint 2007有所不同,SharePoint 2010內允許使用者自行決定使用介面語系的選擇. SharePoint 2010的多 ...

  6. 超強的Linux指令解釋網站《explainshell.com》,學Linux必備!

    ExplainShell 官方網站:http://explainshell.com/ 原始碼下載:https://github.com/idank/explainshell 用瀏覽器打該explain ...

  7. IIS配置發佈網站常見問題及設置

    解决方法: 修改.NET Framework 版本为相应版本即可,我以前用的是2.0换成4.0的时候出现这个错误. 我的win7系统, 1.打开IIs点击IIS根节点 2.看右边的“操作”->点 ...

  8. IIS ApplicationPoolIdentity(配置IIS讀寫網站文件)

    原创地址:http://www.cnblogs.com/jfzhu/p/4067297.html 转载请注明出处 从IIS 7.5开始,Application Pool Identity的Built- ...

  9. MVC學習網站

    http://www.cnblogs.com/haogj/archive/2011/11/23/2246032.html

随机推荐

  1. git使用2

    初始化配置 #配置使用git仓库的人员姓名 git config --global user.name "Your Name Comes Here" #配置使用git仓库的人员em ...

  2. 20145225《Java程序设计》 实验五 Java网络编程及安全

    20145225<Java程序设计> 实验五 Java网络编程及安全 实验报告 一.实验内容 基于Java Socket实现安全传输. 基于TCP实现客户端和服务器,结对编程一人负责客户端 ...

  3. 访问https链接方法

    <a id='___szfw_logo___' href='https://credit.szfw.org/CX20160808028375110138.html' target='_blank ...

  4. jquery实现checkbox的全选

    <html xmlns="http://www.w3.org/1999/xhtml"><head runat="server"> < ...

  5. Javascript数组方法(译)

    在JavaScript中,数组可以使用Array构造函数来创建,或使用[]快速创建,这也是首选的方法.数组是继承自Object的原型,并且他对typeof没有特殊的返回值,他只返回'object'. ...

  6. Element should have been select but was input

    Element should have been select but was input-----看起来像下拉框,但实际不是下拉框的元素内容操作方法如下两名,先点击这个input,再单点要选择的值, ...

  7. struts2--文件上传与下载

    1.文件上传: --表单准备: > 需把HTML表单的enctype属性设置为multipart/form-data; > 需把HTML表单的method属性设置为post: > 需 ...

  8. Sql语句,先查询再插入一条语句完成。

    if ( (select COUNT(*) from Hr where 考勤号码 = '149' and 日期时间 = '2015/7/3 12:00:26') = 0 )INSERT  INTO [ ...

  9. NODE-WEBKIT教程(12)全屏

    node-webkit教程(12)全屏 文/玄魂 目录 node-webkit教程(12)全屏 前言 12.1  和全屏有关的三个api Window.enterFullscreen() Window ...

  10. 基于javascript实现图片懒加载(亲测有效)

    这篇文章主要介绍了javascript实现图片懒加载的方法及思路,有时我们需要用懒加载,也就是延迟加载图片的方式,来提高网站的亲和力,需要的朋友可以参考下! 一.定义 图片延迟加载也称为懒加载,延迟加 ...