碧海长天

好看的皮囊千篇一律,有趣的灵魂万里挑一。

填一个laravel视图缓存没有及时更新的坑

2018-5-5

1.此坑背景
laravel在渲染blade模板后,会将渲染好的结果存到storage/framework/views(默认路径,也可在配置中修改的)中,以便下次使用。
但我最近总是发现修改了blade模板,但怎么刷新都还是有视图缓存。除非执行 php artisan view:clear 清空缓存。

google 好多次,得到了以下结论: 
1.laravel 的视图缓存是无法设置过期时间的。
2.laravel的视图缓存功能是无法关闭的。

如果是这样,那一定是我的开发环境出了问题。因为现状很明显,竟然一直有缓存! 
那么就开始解决问题之路。

2.先说结
我的开发机(用的vmware上的虚拟机)的系统时间和本地时间不一样导致模板文件更新有问题。
解决方法:校准开发机时间~~~~~~~~~~~~~~~~~~~~~~~~~
(我是在windows下写代码 用sftp方式 将文件传到虚拟机上的centos系统  由于最近关闭过虚拟机,莫名其妙的虚拟机上的时间比本地电脑时间快了一天~~~)

3.诊断过程 ----找到laravel源码中的处理逻辑
1) 找到/vendor/laravel/framework/src/Illuminate/View/Compilers/ViewServiceProvider.php 
第134行 registerBladeEngine  模板引擎注册方法 发现其中会创建 BladeCompiler
一看名字就知道是它了  快快进去看一下。

微信图片_20180506000853.png
2) 进入/vendor/laravel/framework/src/Illuminate/View/Compilers/BladeCompiler .php 找到其父类 /vendor/laravel/framework/src/Illuminate/View/Compilers/Compiler.php
看第60行 的 isExpired 方法 

微信图片_20180506000923.png

机智的发现,这里是通过文件的修改时间来判断是否要使用缓存的,且逻辑是 若blade文件的修改时间比缓存文件的时间小时 才会使用缓存。
所以,很可能是我机器的时间问题。
于是查了一下虚拟机的时间。。。。果然不正确。
修改好后,blade缓存不更新的问题 fixed~~~
接下来就是得查为什么我的虚拟机时间突然不对了~~~~  反正vmware奇怪的问题总是那么多 见怪不怪了
完结~

标签: 后端开发 PHP

评论:

林洋洋
2018-05-16 21:16
看不懂,来看看
碧海长天
2018-05-17 10:28
@林洋洋:哈哈哈,可以的~

发表评论: