Redis深入了解内存淘汰与事务操作
来源:脚本之家
时间:2022-12-29 17:22:53 148浏览 收藏
IT行业相对于一般传统行业,发展更新速度更快,一旦停止了学习,很快就会被行业所淘汰。所以我们需要踏踏实实的不断学习,精进自己的技术,尤其是初学者。今天golang学习网给大家整理了《Redis深入了解内存淘汰与事务操作》,聊聊事务操作、Redis内存淘汰,我们一起来看看吧!
Redis内存淘汰策略
为什么要有淘汰策略?
答:将Redis用作缓存时,Redis数据存在内存中,如果内存空间用满,就会自动驱逐老的数据。
redis配置文件:可以配置redis存放数据的阈值(例如:100mb),再配置淘汰策略。
六种淘汰策略
- noeviction:当内存使用达到阈值的时候,所有引起申请内存的命令会报错。
- allkeys-lru:在主键空间中,优先移除最近未使用的key。(推荐)
- volatile-lru:在设置了过期时间的键空间中,优先移除最近未使用的key。
- allkeys-random:在主键空间中,随机移除某个key。
- volatile-random:在设置了过期时间的键空间中,随机移除某个key。
- volatile-ttl:在设置了过期时间的键空间中,具有更早过期时间的key优先移除。
如何配置淘汰策略?
在redis.conf文件中, 设置Redis 内存大小的限制,我们可以设置maxmemory ,当数据达到限定大小后,会选择配置的策略淘汰数据。
比如:maxmemory 300mb。
通过配置 maxmemory-policy 设置Redis的淘汰策略。比如:maxmemory-policy volatile-lru
Redis中的自动过期机制
首先需要配置redis配置文件,开启 key 失效监听。
当key失效时,可以执行我们的客户端回调监听的方法。
需要在Redis中配置:notify-keyspace-events “Ex”
代码在之前的基础上增加:Springboot整合key失效监听
RedisListenerConfig 配置类
@Configuration public class RedisListenerConfig { @Bean RedisMessageListenerContainer container(RedisConnectionFactory connectionFactory) { RedisMessageListenerContainer container = new RedisMessageListenerContainer(); container.setConnectionFactory(connectionFactory); return container; } }
监听 key 的类
@Component public class RedisKeyExpirationListener extends KeyExpirationEventMessageListener { public RedisKeyExpirationListener(RedisMessageListenerContainer listenerContainer) { super(listenerContainer); } @Override public void onMessage(Message message, byte[] pattern) { String expiraKey = message.toString(); System.out.println("失效的key:" + expiraKey); } }
注意:如果是多个springboot项目或者多个 jvm 服务监听同一个key的话,每一个 jvm 都会监听到这个key失效并且执行相应的逻辑代码。
多服务(jvm)监听Redis key失效通知,如何保证只有一个jvm是执行监听的代码?
答:可以使用 zookeeper 的选举机制,多个服务注册到zookeeper中,选举出一个leader,由为 leader 的jvm来执行监听代码。
Redis中的事务操作
- Multi 开启事务
- EXEC 提交事务
- Watch 可以监听一个或者多个key,在提交事务之前是否有发生了变化 如果发生边了变化就不会提交事务,没有发生变化才可以提交事务 版本号码 乐观锁
- Discard 取消提交事务
注意:Redis官方是没有提供回滚方法,只提供了取消事务。
Redis中本身就是单线程的能够保证线程安全问题,不需要考虑线程安全问题。
取消事务跟回滚有什么区别呢?为什么redis不支持回滚事务?
Mysql中开启了事务,对该行数据上行锁—,Commit 数据可以提交
回滚:对事务取消和行锁都会撤销
Redis没有回滚事务的概念,单纯取消事务(不提交事务) 不上锁
watch和Multi的区别
Watch相当于乐观锁,在事务提交之前没有发生变化才可以提交事务。
Multi 就是开启事务,操作数据之后可以提交事务或者取消提交事务。
本篇关于《Redis深入了解内存淘汰与事务操作》的介绍就到此结束啦,但是学无止境,想要了解学习更多关于数据库的相关知识,请关注golang学习网公众号!
-
343 收藏
-
225 收藏
-
105 收藏
-
342 收藏
-
361 收藏
-
159 收藏
-
164 收藏
-
221 收藏
-
156 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 507次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 497次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 484次学习