缓存处理

缓存目的?

减轻服务器的压力,提高检索效率

对什么样的数据进行缓存?

查询大于增删改的时候

长期不变的数据

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集成(之前博客)





  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值