溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

在PHP5.5.34版本中啟用Zend Opcache

發(fā)布時間:2020-07-19 20:40:37 來源:網(wǎng)絡(luò) 閱讀:890 作者:kuSorZ 欄目:web開發(fā)

大家知道目前PHP的緩存插件一般有三個:APC、eAccelerator、XCache,但未來它們可能都會消失,因為PHP 5.5已經(jīng)集成Zend Opcache,功能和前三者相似但又有少許不同,緩存速度據(jù)說比它們更快(注意:只是據(jù)說,我沒測試過)。
這幾個PHP加速插件的主要原理都相同,就是把PHP執(zhí)行后的數(shù)據(jù)緩沖到內(nèi)存中從而避免重復(fù)的編譯過程,能夠直接使用緩沖區(qū)已編譯的代碼從而提高速度,降低服務(wù)器負(fù)載,它們的效率是顯而易見的。
Zend Opcache在PHP 5.5后的版本中已經(jīng)集成了,編譯安裝PHP5.5的時候加上--enable-opcache就行了,也支持低版本的 PHP 5.2.*, 5.3.*, 5.4.*,未來會取消對5.2的支持。

 

如果在編譯安裝php5.5.34的時候,沒有添加--enable-opcache參數(shù),那么在php.ini中添加一些配置參數(shù),啟用即可,php5以后的版本中已經(jīng)內(nèi)置Zend Opcache,所以無需另外安裝


cd /usr/local/php/lib
cp php.ini php.ini.bak #備份配置文件
vim php.ini,shfit+g到最后,添加如下配置

-----------------------------------------------------------------------------------------------------

[opcache]
zend_extension=opcache.so

opcache.interned_strings_buffer=8

opcache.fast_shutdown=1
opcache.enable_cli=1
opcache.enable=1

 

;可用內(nèi)存,酌情而定,單位 megabytes

opcache.memory_consumption=128

 

;最大緩存的文件數(shù)目,命中率不到100%的話,可以試著提高這個值
opcache.max_accelerated_files=4000 

 

;Opcache 會在一定時間內(nèi)去檢查文件的修改時間,這里設(shè)置檢查的時間周期,默認(rèn)為 2,單位為秒

opcache.revalidate_freq=60

------------------------------------------------------------------------------------------------------

如果是nginx環(huán)境,重啟一下php-fpm進(jìn)程即可

查看一下Zend Opcache是否啟用

/usr/local/php/bin/php -v

最后一行帶有 with Zend OPcache等字樣 即表示啟用

 

Opcache的配置參數(shù)詳細(xì)解釋如下:

名字默認(rèn)可修改范圍含義
opcache.enable"1"PHP_INI_ALL是否啟用opcache
opcache.enable_cli"0"PHP_INI_SYSTEM是否在CLI(即命令行時)啟用opcache
opcache.memory_consumption"64"PHP_INI_SYSTEM為opcache分配多少共享內(nèi)存,單位M
opcache.interned_strings_buffer"4"PHP_INI_SYSTEMinterned string的內(nèi)存大小
opcache.max_accelerated_files"2000"PHP_INI_SYSTEM

最大緩存的文件數(shù)目。

實際上這個值會使用第一個大于你配置的數(shù)字的下列素數(shù)

{ 223, 463, 983, 1979, 3907, 7963, 16229, 32531, 65407, 130987 },

如你將該值指定為400,則實際上該值為463.

opcache.max_wasted_percentage"5"PHP_INI_SYSTEM
opcache.use_cwd"1"PHP_INI_SYSTEM

如果置為1,則將當(dāng)前路徑加入到文件key中,

以避免可能產(chǎn)生的同文件名的文件key沖突

opcache.validate_timestamps"1"PHP_INI_ALL

如果置為1,則OPCACHE會自動檢測文件的時間戳

(檢測周期為revalidate_freq),

并根據(jù)文件的時間戳來更新opcode,如果置為0,

則只能手動去重啟opcache或

重啟webserver以使更新后的php文件生效

opcache.revalidate_freq"2"PHP_INI_ALL

opcache自動檢測文件是否更新的周期,單位秒。

如果是0,則每次請求時opcache都要進(jìn)行檢測。

當(dāng)validate_timestamps為0時,本指令無效。

opcache.revalidate_path"0"PHP_INI_ALL
opcache.save_comments"1"PHP_INI_SYSTEM是否保存文件中的注釋
opcache.load_comments"1"PHP_INI_ALL

是否load comments,與save_comments聯(lián)合起來使用,

如果該值為0,則即使save_comments為1,

那么php腳本中的comments也是不使用的

opcache.fast_shutdown"0"PHP_INI_SYSTEM

是否打開快速關(guān)閉,

打開時可使php在request shutdown時回收內(nèi)存快

opcache.enable_file_override"0"PHP_INI_SYSTEM

如果置為1,則每次調(diào)用file_exist() is_file() is_readable()函數(shù)時,

opcache將要檢查該文件是否被cache了,

這樣增加了檢查存在性和可讀性的開銷,

但避免了當(dāng)validate_timestamps為disable時返回錯誤文件狀態(tài)的風(fēng)險。

opcache.optimization_level"0xffffffff"PHP_INI_SYSTEM運行時控制優(yōu)化的掩碼(干什么的?)
opcache.inherited_hack"1"PHP_INI_SYSTEM5.3以前使用。5.3后廢棄
opcache.dups_fix"0"PHP_INI_ALL為解決“cannot redecllare class" 時,可將其置為1
opcache.blacklist_filename""PHP_INI_SYSTEM

設(shè)置黑名單文件,符合黑名單文件中定義的php文件將不被opcache。黑名單文件的例子如下:

; Matches a specific file.
/var/www/broken.php
; A prefix that matches all files starting with x.
/var/www/x
; A wildcard match.
/var/www/*-broken.php
一行為一條規(guī)則,支持通配符,注釋以分號開頭
opcache.max_file_size"0"PHP_INI_SYSTEM被cache的文件的最大size,單位bytes。0表示不限
opcache.consistency_checks"0"PHP_INI_ALL

如果置為N,N非零,則opcache會每N個請求核實一下cache的檢驗和。

這會損害性能,應(yīng)該只在debug時使用

opcache.force_restart_timeout"180"PHP_INI_SYSTEM如果opcache處于非active狀態(tài),當(dāng)N秒后opcache將自動重啟
opcache.error_log""PHP_INI_SYSTEMopcache自身的errorlog文件路徑,為空時則使用stderr
opcache.log_verbosity_level"1"PHP_INI_SYSTEM日志記錄level,默認(rèn)只有fatal error和error
opcache.preferred_memory_model""PHP_INI_SYSTEM

opcache首選使用的內(nèi)存模型,為空時會選擇最適當(dāng)?shù)哪P汀?/p>

常用的有,mmap shm posix 和win32

opcache.protect_memory"0"PHP_INI_SYSTEM

運行php腳本時保護(hù)共享內(nèi)存防止意外的寫入。

只對debug時有用。

 

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI