問題背景
更新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的經驗來說,更新模板後,不會導致PHP報5000
PHP報5000PHP報500因此猜想可能是伺服器的環境問題,列出特殊的設定環境排查。 在預發布環境中,優先檢查加速器eAccelerator。因為eAccelerator
加速器會快取
PHP的
opcode,有可能導致這個問題。 在測試環境進行測試
調試頁面:http://game.37.com/server_list_275.html調試模板:
生成的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
smarty工作原理圖:問題出在更新smarty模板後,雖然smarty
生成了新的編譯文件,但是舊文件的內容仍然被加速器緩存,其中包含了調用文件中一個函數的模板名稱。打開加速器的命中日誌,可以查看相關的記錄:
解決方案1)設定加速器filter
ter,smarty的編譯文件不緩存/*/template_c/*.php"
2)更換為加速器APC
原因:現在使用的eaccelerator是1.0-dev版,並非正式發布的版本。 APC來自官方,並且能下載到stable版本。
以上就介紹了eaccelerator+PHP54導致smarty更新模板500報錯,包括了方面的內容,希望對PHP教程有興趣的朋友有所幫助。
🎜