-
为什么需要缓存:
为了 拉高程序的性能 -
什么样的数据需要缓存:
很少被修改或根本不改的数据 权限
业务场景比如:耗时较高的统计分析sql、电话账单查询sql等 -
什么是二级缓存:
Hibernate提供了一级缓存和二级缓存,合理的利用缓存可以有助于提高系统的性能,为了避免不合理的利用缓存导致内存过度消耗降低系统性能,可以通过合理配置缓存的参数来避免这个问题。
Hibernate中的一级缓存由Session管理,二级缓存由SessionFactory来管理。在使用时,二级缓存是可有可无的,但一级缓存是必不可少的。 -
关系型数据库:数据与数据之间存在关系(联系)的数据库 mysql/Oracle、sqlserver
非关系型数据库:数据与数据之间是不存在关系的,key-value
1、基于文件存储的数据库:ehcache
2、基于内存存储的数据库:redis、memcache
3、基于文档存储的数据库:mongodb -
采用map集合简易实现缓存原理
首先上一张map模拟逻辑图:
接着上测试代码:
package com.swx.six.test;
import java.util.HashMap;
import java.util.Map;
/**
* 利用map集合简易实现缓存原理
* @author Administrator
*
*/
public class EhcacheDemo1 {
static Map<String, Object> cache = new HashMap<String, Object>();
static Object getValue(String key) {
Object value = cache.get(key);
if(value == null) {//如果没有值就进入数据库取值
System.out.println("请求数据库... 第一步");
cache.put(key, new String[] {"zs"});
System.out.println("数据库查出结果集放入缓存... 第二步");
System.out.println("从缓存中读取数据... 第三步");
return cache.get(key);
}else {//如果缓存中有就直接去缓存中拿,就不用去数据库中寻找
System.out.println("从缓存中读取数据... 第四、五、六步");
}
return value;
}
public static void main(String[] args) {
System.out.println(getValue("sname"));
System.out.println(getValue("sname"));
}
}
结果:
可以看见第一次获取getValue(“sname”)的时候是模拟去数据库中拿的,而且其结果也存入了缓存中,而当第二次去拿的时候,就是直接从缓存中拿取了。
- 讲解ehcache
Ehcache 是现在最流行的纯Java开源缓存框架,配置简单、结构清晰、功能强大
首先介绍核心接口:
CacheManager:缓存管理器
Cache:缓存对象,缓存管理器内可以放置若干cache,存放数据的实质,所有cache都实现了Ehcache接口
Element:单条缓存数据的组成单位
ehcache内存结构图:
EhcacheUtil:
package com.swx.six.util;
import net.sf.ehcache.Cache;
import net.sf.ehcache.CacheManager;
import net.sf.ehcache.Element;
import java.io.InputStream;
public class EhcacheUtil {
private static CacheManager cacheManager;
static {
try {
InputStream is = EhcacheUtil.class.getResourceAsStream("/ehcache.xml");
cacheManager = CacheManager.create(is);
} catch (Exception e) {
throw new RuntimeException(e);
}
}
private EhcacheUtil() {
}
public static void put(String cacheName, Object key, Object value) {
Cache cache = cacheManager.getCache(cacheName);
if (null == cache) {
//以默认配置添加一个名叫cacheName的Cache
cacheManager.addCache(cacheName);
cache = cacheManager.getCache(cacheName);
}
cache.put(new Element(key, value));
}
public static Object get(String cacheName, Object key) {
Cache cache = cacheManager.getCache(cacheName);
Element element = cache.get(key);
return null == element ? null : element.getValue();
}
public static void remove(String cacheName, Object key) {
Cache cache = cacheManager.getCache(cacheName);
cache.remove(key);
}
}
ehcache.xml配置文件:
<?xml version="1.0" encoding=