缓存目的?
减轻服务器的压力,提高检索效率
对什么样的数据进行缓存?
查询大于增删改的时候
长期不变的数据
1.一级缓存:sql级别的缓存,mybatis默认使用的缓存,同一个sqlsession对象,执行相同的查询查找,第二次以后会到缓存中加载数据,二不在操作数据库
2.二级缓存:sqlsessionFactory级别的缓存,同一个sqlsession对象,执行相同的查询操作,第二次之后,到缓存中加载数据,而不再操作数据库(1.sqlsession必须关闭掉,缓存才有效果2.一但执行了增删改,缓存会被清空)
1).对象要实例化
2).在mybatis-config配置文件开启缓存
<settings>
<setting name="cacheEnabled" value="true"/>
</settings>
3).在mapper文件中加入缓存标签
<cache></cache>
缺陷:
不支持持久化
容易造成脏数据
2.redis作为缓存服务器
支持持久化操作和多种数据格式
1.jedis客户端操作redis
/**
* jedis工具类
* @author Carry
*
*/
public class JedisUtil {
private static JedisPool pool = null;
static {
try {
//连接池的配置信息:最大连接数、最大空闲数、最小等待数
GenericObjectPoolConfig poolConfig=new GenericObjectPoolConfig();
//设置对应的参数
poolConfig.setMaxTotal(100);
poolConfig.setMaxIdle(10);
//redis的主机地址
String host="192.168.26.138";
//连接池对象
pool = new JedisPool(poolConfig, host);
} catch (Exception e) {
e.printStackTrace();
}
}
/**
* 获取jedis对象的方法
* @return 返回一个jedis对象
*/
public static Jedis getJedis(){
//获取一个连接兑现Jedis
Jedis jedis=null;
if (pool!=null) {
jedis = pool.getResource();
}
return jedis;
}
/**
* 关闭jedis对象的方法
* @param jedis 要关闭的jedis对象
*/
public static void closeJedis(Jedis jedis){
if(jedis!=null){
jedis.close();
}
}
}
spring和redis集成(之前博客)