总评:只是标记一下这种用法hack方法。这种场景下用这种方法还是比较雷人的。
/**
*原创:
*Author:Water.DH(黄俊杰)
*Date :2010-04-18
*/
前言:
Velocity作为一款简单易用的web应用模板框架,深受广大java开发者的喜爱,更多资讯使用搜索"Velocity";来获得。
场景:
Web应用在开发阶段,是不需要配置velocity缓存的,这样修改了vm模板后可以立马生效,调试起来也比较方便。
正式上线后,为了提升性能,我们还是需要开启Velocity缓存,这样vm模板不需要每次访问的时候重新编译,直接从vm缓存中获取。经过测试,在大型Web应用中cpu负载可以降低10%左右。
配置:
web应用中velocity.properties中增加配置如下:
- resource.loader=file
- file.resource.loader.class=org.apache.velocity.tools.view.servlet.WebappLoader
- file.resource.loader.cache=true //缓存开关
- file.resource.loader.modificationCheckInterval=3600 //单位秒
模板缓存1小时。
问题:
很好,现在我们web应用都加上了velocity缓存了,但是页面公共部分有了小修改(比如顶部导航),本来只要发布一个vm模板文件就可以了, 但是为了让模板立马生效,我还得重新启动web服务, 一台两台还好说,我靠,可是如果涉及多个应用和几百台服务器呢?
方案:
把公用的vm模板打上版本号,通过中间的系统管理起来,有了更新后,发送消息给相应的web应用。
web应用这时候要比对版本号,看是否要从中间系统中拉最新的版本内容。
OK,拉到新的模板了,怎么样利用起来呢?
velocity语言中,有个#parse("/WEB-INF/tpl/xxx.vm")函数,用于载入指定路径下的vm文件,这时候我们通过注入工具类的方式,来动态替换这个路径。
比如:
#parse($tool.getPath(xxx.vm));
那其实$tool.getPath(xxx.vm)输出的是带版本号的新地址"/WEB-INF/tpl/xxx_v1102.vm",这样就达到了透过vm缓存的效果。
我们把工具类整合成一个客户端,实现新版本获取,历史文件管理,脱机管理,高并发优化等功能,达到了既不影响性能又简便地集中控制发布的目的。
+
+
+
相关推荐
- 缓存穿透:当请求的数据既不在缓存中也不在数据库中,导致数据库被大量请求穿透。可以通过布隆过滤器预防无效请求。 - 缓存雪崩:大量缓存同时过期,导致请求集中到数据库,引发服务崩溃。解决办法包括设置合理...
最后,狂神还讲解了Redis的常见问题及其解决方案,包括缓存穿透、缓存击穿和缓存雪崩。这三种情况分别指代了不同的缓存失效问题和应对策略。他还提供了Jedis客户端的使用方法以及SpringBoot集成Redis的操作实例。 ...
在缓存问题方面,笔记讨论了缓存穿透、缓存击穿、缓存雪崩等常见问题的解决方案。 通过Jedis这个Java客户端,我们可以方便地在Java项目中集成和操作Redis。Jedis提供了丰富的API,可以实现Redis数据类型的增删改查...
狂神的笔记中提到了每种问题的解决方案,例如使用布隆过滤器防止缓存穿透,设置热点数据永不过期防止击穿,以及设置合理的过期时间和使用互斥锁防止雪崩。 **Jedis API详解** Jedis是Redis的Java客户端,它提供了...
Velocity | 模板引擎 | [http://velocity.apache.org/](http://velocity.apache.org/) ZooKeeper | 分布式协调服务 | [http://zookeeper.apache.org/](http://zookeeper.apache.org/) Dubbo | 分布式服务框架 | ...