java web缓存技术

—背景—

缓存技术在计算机中有关的技术随处可见,不管在硬件还是软件都有着举重轻重的位置,由此可以看到缓存技术的重要性。


—缓存算法—

当然,提到缓存不得不说缓存算法。

最不经常使用算法(LFU):这个缓存算法使用一个计数器来记录条目被访问的频率。通过使用LFU缓存算法,最低访问数的条目首先被移除。这个方法并不经常使用,因为它无法对一个拥有最初高访问率之后长时间没有被访问的条目缓存负责。
最近最少使用算法(LRU):这个缓存算法将最近使用的条目存放到靠近缓存顶部的位置。当一个新条目被访问时,LRU将它放置到缓存的顶部。当缓存达到极限时,较早之前访问的条目将从缓存底部开始被移除。这里会使用到昂贵的算法,而且它需要记录“年龄位”来精确显示条目是何时被访问的。此外,当一个LRU缓存算法删除某个条目后,“年龄位”将随其他条目发生改变。
自适应缓存替换算法(ARC):在IBM Almaden研究中心开发,这个缓存算法同时跟踪记录LFU和LRU,以及驱逐缓存条目,来获得可用缓存的最佳使用。
最近最常使用算法(MRU):这个缓存算法最先移除最近最常使用的条目。一个MRU算法擅长处理一个条目越久,越容易被访问的情况。

—Java web缓存—

在Java中最简单和最常见的应该就是static静态的Map缓存方式。


—缓存技术设计思想—

典型的空间换时间。


—缓存—

        缓存就是将静态资源、文件、数据库等会频繁被使用到的数据或者资源存储在系统外。一般我们操作数据库、硬盘文件等资源,我们的做法是每次都从数据库或者硬盘上去获取,这样就会速度很慢,造成性能问题。而解决这一个简单的方法就是:把这些数据缓存到内存里面,每次操作的时候,先到内存里面找,看有没有这些数据,如果有,那么就直接使用,如果没有那么就获取它,并设置到缓存中,下一次访问的时候就可以直接从内存中获取了。


—实现基本步骤—

(1)先到缓存里面查找所要查找的想用数据,看看是否存在需要使用的数据
(2)如果没有找到,那么就创建一个满足要求的数据,然后把这个数据设置回到缓存中,以备下次使用
(3)如果找到了相应的数据,或者是创建了相应的数据,那就直接使用这个数据。


—缓存存在的问题—

缓存数据存放时间问题
缓存数据和真实数据的同步问题
缓存的多线程并发的控制


评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值