Liferay Dynamic CSS Filter方法的研究 - 缓存文件存在的处理

本文涉及的产品
全局流量管理 GTM,标准版 1个月
云解析 DNS,旗舰版 1个月
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
简介:

引入:

现在我们接着上文章讨论来解决疑问3:对于缓存文件已经存在和不存在的情况有什么特别处理。


分析:

现在我们先来看下如果缓存文件已经存在时候的处理方式


因为我们开始已经创建了一个缓存文件,它的base名字为$CATALINA_TMPDIR/liferay/css/portal/6476841388170400461

160623788.png


假定我们上次访问的路径是main.css文件,那么这次当我们再访问main.css文件的时候,我们就发现它走了第120行。它会先判断缓存文件的最后修改时间戳(cacheDataFile.lastModified())和原始文件的最后修改时间戳(file.lastModified()),如果前者偏大,则说明缓存文件是最新的,那么它就124行直接把缓存文件的内容类型文件的contentType读取出来,然后

161131183.png

第126行吧httpServletResponse的返回类型设置为这个缓存文件内容类型(回想以前曾说过,第一次设置时候这个值应该是text/css),最后吧缓存的数据文件放到输出流中。

然后在第DynamicCSSFilter中第217行用

161356787.png

使用ServletResponseUtil 读取这个缓存文件中的内容并且输出到客户端。


所以客户端就可以获得最新版本的解析后的普通css资源文件并且使用了。(这个过程中并没有JRuby解析Sass生成css,所以减少好多IO操作,效率提高了很多)




下面我们再来看下缓存不存在,从头生成这些文件的例子:

假如我们清空了tomcat的temp目录吧这些缓存文件都清空,那么显然,它没办法走缓存路线(也就是不走if(cacheDataFile.exists()分支),所以它会去生成新的。

让我们回到原始的讨论,如下所示,在142行是从原始的带Sass的样式文件中读取的css文件,存放到content中

162721297.png

然后第144行解析Sass文件获取的普通css文件存放到dynamicContent中,我们可以比较看出明显不同.


尤其是在@import这种语法后,转为的新的都加了很多参数。


这时候,调用第149行的FileUtil.write(cacheContentTypeFile, ContentTypes.TEXT_CSS)会写入内容类型文件:

163401168.png

从服务器看,当前目录下只有一个文件<baseName>_E_CONTENT_TYPE,这是合乎情理的,因为数据文件还没创建呢,才刚刚写内容类型文件,而且写的时间也和当前的时间戳吻合,说明是刚才才写入的这个文件,并且这个文件内容只有text/css,所以这个文件很小,只有8个字节。


然后第193行,就会吧生成的普通css文件内容(也就是存放在dynamicContent变量中)写入到数据文件中,调用是第193行FileUtil.write(cacheDataFile.dynamicContent);

163639977.png


我们看下服务器目录,果然现在生成了<baseName>_E_DATA文件:

163830443.png

这个文件从时间戳看比刚才的内容文件晚5分钟,这也合乎常理,因为我在调试,要单步走,并且还有截图,写文章,所以确信,这正是调试点所执行到时候创建的文件,并且文件大小是874字节,这个也刚好和我们的dynamicContent的大小一样,如下图:

164027694.png


一切都是那么吻合和完美。



结论:

(1)当请求的资源文件已经在Liferay的缓存中(也就是在$CATALINA_TMPDIR/liferay/css/folder/<hashcode>时候,服务器会去比较缓存中的资源文件的最近使用时间戳和原始资源文件的最近使用时间戳,如果缓存的时间戳比较新,那么就直接从缓存中读取内容类型信息和被解析后的普通css文件,然后构造输出流输出到客户端。

(2)当请求的资源文件没有在Liferay缓存中,那么Liferay框架会自己在缓存目录中构建相应的目录和文件,并且先是写内容类型文件,再写缓存数据文件(Sass解析后得到的普通css文件),最终把这些内容通过输出流输出到客户端。





本文转自 charles_wang888 51CTO博客,原文链接:http://blog.51cto.com/supercharles888/1282865,如需转载请自行联系原作者
目录
相关文章
|
2月前
|
前端开发
在Webpack配置文件中,如何配置loader以处理其他类型的文件,如CSS或图片
在Webpack配置文件中,通过设置`module.rules`来配置loader处理不同类型的文件。例如,使用`css-loader`和`style-loader`处理CSS文件,使用`file-loader`或`url-loader`处理图片等资源文件。配置示例:在`rules`数组中添加对应规则,指定`test`匹配文件类型,`use`指定使用的loader。
|
3月前
|
缓存 Java Shell
Android 系统缓存扫描与清理方法分析
Android 系统缓存从原理探索到实现。
107 15
Android 系统缓存扫描与清理方法分析
|
2月前
|
存储 缓存 监控
利用 Redis 缓存特性避免缓存穿透的策略与方法
【10月更文挑战第23天】通过以上对利用 Redis 缓存特性避免缓存穿透的详细阐述,我们对这一策略有了更深入的理解。在实际应用中,我们需要根据具体情况灵活运用这些方法,并结合其他技术手段,共同保障系统的稳定和高效运行。同时,要不断关注 Redis 缓存特性的发展和变化,及时调整策略,以应对不断出现的新挑战。
81 10
|
2月前
|
缓存 监控 前端开发
CSS 提高性能的方法
【10月更文挑战第24天】在实际应用中,还需要根据具体项目的特点和需求,灵活选择和组合这些方法,不断进行优化和改进。同时,随着技术的不断发展,也需要持续关注新的性能优化技巧和最佳实践,以保持在性能优化方面的领先地位。你对 CSS 性能优化还有哪些深入的思考和经验呢?欢迎进一步交流和分享。
|
2月前
|
缓存 监控 NoSQL
Redis 缓存穿透的检测方法与分析
【10月更文挑战第23天】通过以上对 Redis 缓存穿透检测方法的深入探讨,我们对如何及时发现和处理这一问题有了更全面的认识。在实际应用中,我们需要综合运用多种检测手段,并结合业务场景和实际情况进行分析,以确保能够准确、及时地检测到缓存穿透现象,并采取有效的措施加以解决。同时,要不断优化和改进检测方法,提高检测的准确性和效率,为系统的稳定运行提供有力保障。
66 5
|
2月前
|
前端开发
css页面顶部底部固定,中间自适应几种方法
【10月更文挑战第22天】css页面顶部底部固定,中间自适应几种方法
|
3月前
|
SQL 缓存 Java
JVM知识体系学习三:class文件初始化过程、硬件层数据一致性(硬件层)、缓存行、指令乱序执行问题、如何保证不乱序(volatile等)
这篇文章详细介绍了JVM中类文件的初始化过程、硬件层面的数据一致性问题、缓存行和伪共享、指令乱序执行问题,以及如何通过`volatile`关键字和`synchronized`关键字来保证数据的有序性和可见性。
49 3
|
3月前
|
前端开发 容器
CSS 中几种常用的换行方法
CSS 中几种常用的换行方法
42 1
|
3月前
|
缓存 NoSQL 算法
解决Redis缓存雪崩问题的有效方法
解决Redis缓存雪崩问题的有效方法
62 1
|
4月前
|
存储 缓存 NoSQL
解决Redis缓存击穿问题的技术方法
解决Redis缓存击穿问题的技术方法
94 2