php加速引擎 zend詳解

2021-10-04 09:24:26 字數 1529 閱讀 4281

php的加速外掛程式有三個:zend optimizer、zend guard loader 和 zend opcache。但其實都是乙個,針對不通的php版本。名字叫法不一樣而已。

zend optimizer 是針對php 5.3.x 之前用的外掛程式名稱。
zend guard loader 是針對php 5.3.x 到php5.6 之間的外掛程式名稱
zend opcache 是針對php5.6之後包括php7.0之後使用的外掛程式名稱。
zend opcache通過 opcode 快取和優化提供更快的 php 執行過程。它將預編譯的指令碼檔案儲存在共享記憶體中供以後使用,從而避免了從磁碟讀取**並進行編譯的時間消耗。同時,它還應用了一些**優化模式,使得**執行更快。

當直譯器完成對指令碼**的分析後,便將它們生成可以直接執行的中間**,也稱為操作碼(operate code,opcode)。opcode cache 的目地是避免重複編譯,減少 cpu 和記憶體開銷。如果動態內容的效能瓶頸不在於 cpu 和記憶體,而在於 i/o 操作,比如資料庫查詢帶來的磁碟 i/o 開銷,那麼 opcode cache 的效能提公升是非常有限的。但是既然 opcode cache 能帶來 cpu 和記憶體開銷的降低,這總歸是好事!

現代操作碼快取器(optimizer+,apc2.0+,其他)使用共享記憶體進行儲存,並且可以直接從中執行檔案,而不用在執行前「反序列化」**。這將帶來顯著的效能加速,通常降低了整體伺服器的記憶體消耗,而且很少有缺點。

修改php.ini 搜尋 : 「[opcache]」

增加以下**(或者在原有基礎上改一下):

zend_extension = php_opcache.dllopcache.enable=1opcache.enable_cli=1opcache.memory_consumption=128

opcache.max_accelerated_files=2000

幾個重要引數的作用說明:

opcache.enable=1 //開啟opcacheopcache.enable_cli=1 //是否在cli(即命令行時)啟用opcacheopcache.memory_consumption=128 //共享記憶體的大下 可以根據專案大小和伺服器配置自行調整opcache.max_accelerated_files=2000 //最大快取檔案個數

設定好後,重啟apache即可。開啟phpinfo觀察變化:

證明 zend opcache 已經成功開啟。經過測試效果明顯(因為減少了編譯次數也減少了磁碟io開銷)

PHP核心 Zend引擎

在前面的章節介紹了php的生命週期,php的sapi,sapi處於php整個架構較上層,而真正指令碼的執行主要由zend引擎來完成,這一小節我們介紹php指令碼的執行。目前程式語言可以分為兩大類 但它們並不是真的直接就被能被機器理解,機器只能理解機器語言,那這些語言是怎麼被執行的呢,一般這些語言都需...

PHP核心 Zend引擎

在前面的章節介紹了php的生命週期,php的sapi,sapi處於php整個架構較上層,而真正指令碼的執行主要由zend引擎來完成,這一小節我們介紹php指令碼的執行。目前程式語言可以分為兩大類 但它們並不是真的直接就被能被機器理解,機器只能理解機器語言,那這些語言是怎麼被執行的呢,一般這些語言都需...

Zend引擎的優化

在php 5.4的更新list上,有一句 提公升了zend引擎的效能,減少了記憶體占用.那麼,到底是怎麼提公升的呢?我們知道在php中,類的屬性 靜態屬性 常量,都是儲存在hashtable中的,而在以前,即使乙個類沒有申明屬性 靜態屬性 常量,zend引擎也會為他們分配hashtable.而在現在...