问题背景
更新game.37.com业务的smarty模板后,服务器上出现多条500报错记录。PHP错误日志中的报错如下:
[16-May-2016 15:46:01 Asia/Shanghai] PHP Fatal error: Call to undefined function content_57397470478e99_59376883() in /*/template_c/6aede77242b285842c628673e93d8bf1bd4bc6b0.file.server_list.htm.php on line 67
现象:更新模板后,首次访问报500错误,再次访问正常。
问题排查
按正常使用smarty的经验来说,更新模板后,不会导致PHP报500错误。因此猜想可能是服务器的环境问题,列出特殊的配置环境排查。
在预发布环境中,优先检查加速器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模板后的2个编辑文件,发现PHP报错原因是调用了旧模板中的函数。
PHP的异常报错信息PHP Fatal error: Call to undefined function content_573a944d7a2608_39051073() in /*/template_c/6aede77242b285842c628673e93d8bf1bd4bc6b0.file.server_list.htm.php on line 67
smarty工作原理图:

问题出在更新smarty模板后,虽然smarty生成了新的编译文件,但是旧文件的内容仍然被加速器缓存,其中包含了调用模板文件中一个函数的名称。打开加速器的命中日志,可以查看到相关的记录:
解决方案
1)配置加速器filter参数,smarty的编译文件不缓存
eaccelerator.filter="!/*/template_c/*.php"
但是要评估对性能的影响
2)更换为加速器APC
原因:现在使用的eaccelerator是1.0-dev版,并非正式发布的版本。APC来源于官方,并且能下载到stable版本。
以上就介绍了eaccelerator+PHP54导致smarty更新模板500报错,包括了方面的内容,希望对PHP教程有兴趣的朋友有所帮助。

tomakephpapplicationsfaster,关注台词:1)useopcodeCachingLikeLikeLikeLikeLikePachetoStorePreciledScompiledScriptbyTecode.2)MinimimiedAtabaseSqueriSegrieSqueriSegeriSybysequeryCachingandeffeftExting.3)Leveragephp7 leveragephp7 leveragephp7 leveragephpphp7功能forbettercodeefficy.4)

依赖性(di)inphpenhancesCodeFlexibility andTestability by decouplingClassesscyclasses fromtheippentencies.1)UseConstructorientoctionTopAssDopassDectiesViactructors Viactructors

推荐Pimple用于简单项目,Symfony的DependencyInjection用于复杂项目。1)Pimple适合小型项目,因其简单和灵活。2)Symfony的DependencyInjection适合大型项目,因其功能强大。选择时需考虑项目规模、性能需求和学习曲线。

依赖性注射(DI)InphpisadesignpatternwhereClassDepentenciesArepassedtotosedTosedTosedTotratherThancReateDinterally,增强codemodemodularityAndTestabily.itimprovessoftwarequalitybyby By:1)增强tosestabilityTestabilityTestabilityThroughityThroughEasyDepentyDepententymydependentymocking,2)增强Flexibilybya

依赖性(di)InphpenhancesCodemodularity,可检验性和确定性。1)itallowSeasysWappingOfComponents,AsseeninaPaymentGateWayswitch.2)dicanbeimimplementlededMermplemplemplemplemplemplemplemplemplempletallyororororerorviacontainers,withcontanersAddingComplexiteDcomplexiteDcomplexiteDcomplexitingCompleaDdingCompleAddingButaidLararArargerProprproproprys.3)

TOOPTIMIZEPHPCODEFORDUSEMEMORYUSAGEAGEAGEAGEAGEAGEANDEXECUTITIEM,关注台词:1)USEREEREFERESCENCENCINCOPYINSTEADOFCOPYINGINATATASTRUCTURESTROUCTURESTOREDUCEMORYCONSUMPTION.2)杠杆phphppphpphp'sbuilt intimpunctionslikearray_mapforfunctionslikearray_mapforfforfforfforfasterapasterexecution.3)

phpisusedforsendendemailsduetoitsignegrationwithservermailservicesand andexternalsmtpproviders,自动化notifications andMarketingCampaigns.1)设置设置yourphpenvironcormentswironmentswithaweberswithawebserverserverserverandphp,确保themailfunctionisenabled.2)useabasicscruct

发送电子邮件的最佳方法是使用PHPMailer库。1)使用mail()函数简单但不可靠,可能导致邮件进入垃圾邮件或无法送达。2)PHPMailer提供更好的控制和可靠性,支持HTML邮件、附件和SMTP认证。3)确保正确配置SMTP设置并使用加密(如STARTTLS或SSL/TLS)以增强安全性。4)对于大量邮件,考虑使用邮件队列系统来优化性能。


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

适用于 Eclipse 的 SAP NetWeaver 服务器适配器
将Eclipse与SAP NetWeaver应用服务器集成。

记事本++7.3.1
好用且免费的代码编辑器

EditPlus 中文破解版
体积小,语法高亮,不支持代码提示功能

MinGW - 适用于 Windows 的极简 GNU
这个项目正在迁移到osdn.net/projects/mingw的过程中,你可以继续在那里关注我们。MinGW:GNU编译器集合(GCC)的本地Windows移植版本,可自由分发的导入库和用于构建本地Windows应用程序的头文件;包括对MSVC运行时的扩展,以支持C99功能。MinGW的所有软件都可以在64位Windows平台上运行。

ZendStudio 13.5.1 Mac
功能强大的PHP集成开发环境