Redis05——超时和垃圾回收

一、Redis的超时命令
 正如 Java 虚拟机,它提供了自动 GC(垃圾回收)的功能,来保证 Java 程序使用过且不再使用的 Java 对象及时的从内存中释放掉,从而保证内存空间足够使用。当程序编写不当或考虑欠缺的时候(比如读入大文件),内存就可能存储不下运行所需要的数据,那么 Java 虚拟机就会抛出内存溢出的异常而导致服务不可用。同样,Redis 也是基于内存而运行的数据集合,也存在着对内存垃圾的回收和管理的问题。
 Redis 基于内存,而内存对于一个系统是最为宝贵的资源,而且它远远没有磁盘那么大,所以对 Redis 的键值对的内存回收也十分重要,如果操作不当会产生 Redis 宕机的问题,使得系统性能低下。
 一般而言,和 Java 虚拟机一样,当内存不足时 Redis 会触发自动垃圾回收的机制,而程序员可以通过 System.gc() 去建议 Java 虚拟机回收内存垃圾,它将“可能”(注意,System.gc() 并不一定会触发 JVM 去执行回收,它仅仅是建议 JVM 做回收)触发一次 Java 虚拟机的回收机制,但是如果这样做可能导致 Java 虚拟机在回收大量的内存空间的同时,引发性能低下的问题。
 对于 Redis 而言,del 命令可以删除一些键值对,所以 Redis 比 Java 虚拟机更灵活,允许删除一部分的键值对。与此同时,当内存运行空间满了之后,它还会按照回收机制去自动回收一些键值对,这和 Java 虚拟机又有相似之处,但是当垃圾进行回收的时候,又有可能因执行回收而引发系统停顿,因此选择适当的回收机制和时间将有利于系统性能的提高。
 在谈论 Redis 内存回收之前,首先要讨论的是键值对的超时命令,因为大部分情况下,我们都想回收那些超时的键值对,而不是那些非超时的键值对。对于 Redis 而言,可以给对应的键值设置超时:
在这里插入图片描述
二、Spring中使用超时命令

SessionCallback callBack = new SessionCallback() {
	@Override
	public Object execute(RedisOperations ops) throws DataAccessException {
		ops.boundValueOps("key1").set("value1");
		String keyValue = (String) ops.boundValueOps("key1").get();
		Long expSecond = ops.getExpire("key1");
		System.err.println(expSecond);
		boolean b = false;
		b = ops.expire("key1", 120L, TimeUnit.SECONDS);
		b = ops.persist("key1");
		Long l = 0L;
		l = ops.getExpire("key1");
		Long now = System.currentTimeMillis();
		Date date = new Date();
		date.setTime(now + 120000);
		ops.expireAt("key", date);
		return null;
	}
};
redisTemplate.execute(callBack);

三、垃圾回收
 需要非常注意的是:Redis 的 key 超时并不会被立即回收,而只是标识哪些键值对超时了。这样做的好处在于,如果一个很大的键值对超时,比如一个列表或者哈希结构,存在数以百万个元素,要对其回收需要很长的时间。如果采用超时立即回收,则可能产生停顿。但这些超时的键值对又会浪费比较多的空间,因此Redis 提供了两种方式回收这些超时键值对,它们是定时回收和惰性回收:
  定时回收:是指在确定的某个时间触发一段代码,回收超时的键值对
  惰性回收:是当一个超时的键,被再次用 get 命令访问时,将触发回收将其从内存中删除
 定时回收可以完全回收那些超时的键值对,但是缺点也很明显,如果这些键值对比较多,则 Redis 需要运行较长的时间,从而导致停顿。所以系统设计者一般会选择在没有业务发生的时刻触发 Redis 的定时回收。
 对于惰性回收而言,它的优势是可以指定回收超时的键值对,它的缺点是要执行一个莫名其妙的 get 操作,或者在某些时候,我们也难以判断哪些键值对已经超时。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值