首頁  >  文章  >  後端開發  >  eaccelerator+PHP54導致smarty更新模板500報錯

eaccelerator+PHP54導致smarty更新模板500報錯

WBOY
WBOY原創
2016-07-29 08:49:021392瀏覽

問題背景

更新game.37.com業務的smarty範本後,伺服器上出現多重500範本後,伺服器上出現多筆5000記錄。 PHP

錯誤日誌中的報錯如下:

[16-May-2016 15:46:01 Asia/Shanghai] PHP Fatal error:  Call to undefined function content_573898507382 /6aede77242b285842c628673e93d8bf1bd4bc6b0.file .server_list.htm.php on line 67現象:更新模板後,首次訪問報500

錯誤,再次訪問正常。

問題排查以正常使用smarty的經驗來說,更新模板後,不會導致PHP5000

PHP

5000PHP500因此猜想可能是伺服器的環境問題,列出特殊的設定環境排查。 在預發布環境中,優先檢查加速器eAccelerator。因為eAccelerator

加速器會快取
PHP

opcode,有可能導致這個問題。 在測試環境進行測試 調試頁面:http://game.37.com/server_list_275.html調試模板:

main.htm

生成的smarty

編譯文件:/*/template_c/6aede77242b285842c628673e93d8bf1bd4bc6b0.file .server_list.htm.php檢查smarty的編譯檔對比更新smarty

模板後的錯誤,c模板中的函數。 PHP的異常報錯訊息

PHP Fatal error:  Call to undefined function content_573a944d7a2608_39051073() in /6727262627262623() ind 4bc6b0.file.server_list.htm.php on line 67

smartyeaccelerator+PHP54導致smarty更新模板500報錯工作原理圖:

問題出在更新smarty模板後,雖然smarty

生成了新的編譯文件,但是舊文件的內容仍然被加速器緩存,其中包含了調用文件中一個函數的模板名稱。打開加速器的命中日誌,可以查看相關的記錄:eaccelerator+PHP54導致smarty更新模板500報錯

解決方案1)設定加速器filter

ter,smarty的編譯文件不緩存/*/template_c/*.php"

但是要評估對性能的影響

2)更換為加速器APC
原因:現在使用的eaccelerator是1.0-dev版,並非正式發布的版本。 APC來自官方,並且能下載到stable版本。


以上就介紹了eaccelerator+PHP54導致smarty更新模板500報錯,包括了方面的內容,希望對PHP教程有興趣的朋友有所幫助。

🎜
陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn