java缓存技术
来源:互联网 发布:全球经济数据库 市盈率 编辑:程序博客网 时间:2024/06/08 17:05
1、Java缓存
(1)单个对象的缓存
一个对象就是数据库一行记录,对于单个对象的缓存,用HashMap就可以了,稍微复杂一点用LRU算法包装一个HashMap,再复杂一点的分布式用memcached即可;
(2)列表缓存
就像论坛里帖子的列表;
(3)长度的缓存
比如一个论坛板块里有多少个帖子,这样才方便实现分页
(4) 复杂一点的group,sum,count查询
比如一个论坛里按点击数排名的最HOT的帖子列表。第一种比较好实现,后面三种比较困难,似乎没有通用的解决办法,我暂时以列表缓存
1.1 CacheManager(第二种)为例分析
从设计的角度来看,基本的概念是一个CacheManager保存和控制一系列的缓存。缓存有很多条目(entries)。基本的API可以被当做是一个类似map并拥有下面一些特点的东西:
(1)原子操作,跟java.util.ConcurrentMap类似
(2)从缓存中读取
(3)写入缓存
(4)缓存事件监听器
(5)数据统计
(6)包含所有隔离(ioslation)级别的事务
(7)缓存注解(annotations)
(8)保存定义key和值类型的泛型缓存
(9)引用保存(只适用于堆缓存)和值保存定义
1.2 具体实现
1 、 CacheManager 对象的创建方式
(1)Create a singleton CacheManager using defaults, then list caches.
CacheManager manager = CacheManager.create();String[] cacheNames = CacheManager.getInstance().getCacheNames();
(2)Create a CacheManager instance using defaults, then list caches.
CacheManager manager = new CacheManager();String[] cacheNames = manager.getCacheNames();
(3)Create two CacheManagers, each with a different configuration, and list the caches in each.
CacheManager manager1 = new CacheManager("src/config/ehcache1.xml");CacheManager manager2 = new CacheManager("src/config/ehcache2.xml");String[] cacheNamesForManager1 = manager1.getCacheNames();String[] cacheNamesForManager2 = manager2.getCacheNames();
2 、 Cache 配置文件的加载方式
CacheManager 的构造函数如下:
(1) 无参
CacheManager manager = new CacheManager();
(2) 通过配置文件
CacheManager manager = new CacheManager("src/config/ehcache.xml");
(3) 通过资源
URL url = getClass().getResource("/anotherconfigurationname.xml");CacheManager manager = new CacheManager(url);
(4) 通过输入流
InputStream fis = new FileInputStream(new File("src/config/ehcache.xml").getAbsolutePath());try { CacheManager manager = new CacheManager(fis);} finally { fis.close();}
3 、增加或删除 Cache
增加 Cache 有两种方式:
(1) 使用 CacheManager 的 addCache(String)
CacheManager singletonManager = CacheManager.create();singletonManager.addCache("testCache");Cache test = singletonManager.getCache("testCache");
(2) 新增一个 Cache ,然后加到 CacheManager 中, Cache 在加入 CacheManager 之前是不能使用的
CacheManager singletonManager = CacheManager.create();Cache memoryOnlyCache = new Cache("testCache", 5000, false, false, 5, 2);manager.addCache(memoryOnlyCache);Cache test = singletonManager.getCache("testCache");
3、从 CachaManager 中删除 Cache
CacheManager singletonManager = CacheManager.create();singletonManager.removeCache("sampleCache1");
4 、关闭 CacheManager
CacheManager 在使用之后应该关闭,虽然有自己的 shutdown hook ,建议在程序中手动关闭。
CacheManager.getInstance().shutdown();
5、缓存配置
<?xml version="1.0" encoding="UTF-8"?> <ehcache> <!--timeToIdleSeconds 当缓存闲置n秒后销毁 --> <!--timeToLiveSeconds 当缓存存活n秒后销毁 --> <\ehcache>
cache配置文件
cache方法类
public class EhcacheUtil { private static final String path = "/ehcache.xml"; private URL url; private CacheManager manager; private static EhcacheUtil ehCache; private EhcacheUtil(String path) { url = getClass().getResource(path); manager = CacheManager.create(url); } public static EhcacheUtil getInstance() { if (ehCache == null) { ehCache = new EhcacheUtil(path); } return ehCache; } public void put(String cacheName, String key, Object value) { Cache cache = manager.getCache(cacheName); Element element = new Element(key, value); cache.put(element); } public Object get(String cacheName, String key) { Cache cache = manager.getCache(cacheName); Element element = cache.get(key); return element == null ? null : element.getObjectValue(); } public Cache get(String cacheName) { return manager.getCache(cacheName); } public void remove(String cacheName, String key) { Cache cache = manager.getCache(cacheName); cache.remove(key); }}
- java缓存技术讨论
- java缓存技术
- JAVA缓存技术
- JAVA缓存技术-jnotify
- java缓存技术
- java缓存技术
- JAVA缓存技术
- java 缓存技术
- java缓存技术
- JAVA缓存技术
- java缓存技术
- JAVA缓存技术
- JAVA缓存技术(1)
- java的缓存技术
- JAVA缓存技术
- Java缓存技术
- java缓存技术
- java中的缓存技术
- IIC协议
- Unity 3D
- WindowManager.LayoutParams详解总结和对应实例
- 哈密顿图 poj 1776
- 存储过程例子
- java缓存技术
- java-final关键字
- Linux C 读取文件夹下所有文件(包括子文件夹)的文件名(转载)
- 多条件查询--使用dapper命令参数动态拼接出最安全的sql语句
- 前端代码书写规范
- hdu 2047简单递推公式
- 钓鱼比赛
- 结构型模式之适配器模式(Adapter)
- php