一种简单的本地cache的实现
来源:互联网 发布:淘宝排名 编辑:程序博客网 时间:2024/05/20 21:43
我们经常在web应用中需要对某些数据进行本地cache,特别是一些存在数据库或者其他需要访问其他服务的数据进行本地cache,如果这些数据更新不频繁,或者很少更新,而且对数据更新允许有一定的时间才反映到线上的话,那么下面这种方案个人觉得比较简单方便,不需要使用memcache等集中式缓存之类来实现。
直接在web应用中使用定时器和InitializingBean来实现即可:
请看service类:
下面这个idNameCacheMap就是我们需要进行数据缓存的对象,在spring加载完之后的afterPropertiesSet获取缓存数据进行加载,然后使用pring的quartz定时器进行定时更新,
这种方式简单,而且不用担心集群中不同服务器数据的不一致,定时器更新能够保证数据的不一致性的时间非常短,而且应用已启动就会加载数据,定时器更新的频率更新需要进行设置。我看到有很多使用timer类来处理,在java代码中启动一个线程,线程启动后就加载数据,然后sleep一段时间后更新缓存数据。这种其实应用的不同服务器启动的时间相差比较大,可能导致服务器间数据不一致时间会比较长。
import java.util.HashMap;import java.util.Map;import javax.annotation.Resource;public class LocalCacheService implements InitializingBean{ private Map<Long, String> idNameCacheMap = new HashMap<Long, String>(); @Resource private DataService dataService; public void update(){ Map<Long,String> tmpMap = dataService.getLastest(); if(tmpMap != null && !tmpMap.isEmpty()){ this.idNameCacheMap = tmpMap; } } @Override public void afterPropertiesSet() throws Exception { try { update(); } catch (Exception e) { } }}
<bean id="localCacheService" class="org.LocalCacheService" > </bean> <bean id="localCacheListenerTrigger" class="org.springframework.scheduling.quartz.CronTriggerBean"> <property name="jobDetail"> <bean class="org.springframework.scheduling.quartz.MethodInvokingJobDetailFactoryBean"> <property name="targetObject" ref=""localCacheService""> </property> <property name="targetMethod"> <value>update</value> </property> </bean> </property> <property name="cronExpression"> <value>0 0/30 * * * ?</value> </property> </bean> <bean class="org.springframework.scheduling.quartz.SchedulerFactoryBean" autowire="no"> <property name="triggers"> <list> <ref bean="localCacheListenerTrigger" /> </list> </property> </bean>
- 一种简单的本地cache的实现
- LRU Cache的一种实现
- 本地cache简单代码实现
- LRU cache的简单实现
- LRU Cache的简单实现
- android 本地验证码的一种实现
- android 本地验证码的一种实现
- 分布式本地缓存的一种实现
- vector的一种简单实现
- 九九乘法表的一种简单实现
- (1)从最简单的本地cache讲起
- 用LinkedHashMap实现的简单LRU Cache
- LRU Cache的简单c++实现
- LRU cache的一个简单实现
- java实现简单的LRU Cache
- HashMap实现简单的缓存Cache
- Spring Cache的原理和简单实现
- 用Hashtable实现简单的cache缓存
- STL中map、set的数据结构及底层实现
- android sd卡读取图片 并处理大图
- C# yield关键字
- 不适用变量实现c语言的strlen函数
- 邂逅的工具软件,有时间再去尝试!
- 一种简单的本地cache的实现
- 无向图基本算法 -- 遍历及最小生成树算法
- 对Objective-c委托的理解
- 1. objC 动态类型(dynamic typing)
- 有向图基本算法 -- 遍历算法
- 编程心得
- 自定制VS插件(一)--LearnVSXNow! - #1: 如何开始VS扩展包(VSX/VS SDK)的编程?
- Rabin-Miller概率素数检验算法
- C++编程必备