redis(4)

本文详细介绍了Redis中的事务机制,包括如何开启和终止事务,以及在遇到错误时如何处理。同时,讨论了Redis的锁机制,如单机锁和分布式锁的实现,并提出了分布式锁的改良方案,以防止死锁。此外,文章还探讨了Redis的过期删除策略,包括定时删除、惰性删除和定期删除,以及它们的优缺点。最后,提到了内存不足时的逐出算法,用于在内存压力下选择性地清理数据。
摘要由CSDN通过智能技术生成

redis中的事务

事务的基本操作

在这里插入图片描述
开启事务之后,后面的指令都会存在事务队列中,一旦执行exec命令,就会按照顺序一条一条执行
在这里插入图片描述
在这里插入图片描述
这里在事务中输入discard命令之后,就会终止事务,这样整个事务就终止,其中的代码也不会运行,a的值也不会改变。
在这里插入图片描述

使用事务的注意事项

这里需要注意,如果是命令格式,语法问题,那么整个事务中的命令都不会执行,但是如果是命令格式正确,但是无法正确的执行,那么正确的都会执行,只有不正确的代码不会执行。需要手动去回滚
在这里插入图片描述
这里get a 3为语法错误,整个事务都不会执行
在这里插入图片描述
这里可以看到在test中存储了一个非数字的字符串,然后让他自增1,这样实际上是会报错误的,执行了事务之后,给test赋值的操作却还是被执行了。
在这里插入图片描述

手动回滚

一般不手动回滚
所以redis的事务实际上用的比较少
在这里插入图片描述

如果有多个客户端对同一个数据进行操作,这时候就要确保有锁
在这里插入图片描述

在这里插入图片描述
在第一个客户端上:
在这里插入图片描述
第二个客户端上:
在这里插入图片描述
在第一个客户端上给test加了锁,然后在事务中输入获取test值的命令,然后在第二个客户端中改变test的值,这时候在第一个客户端中执行exec命令,会发现这时候操作失败了。因为test的值被改变了,这时候就终止了事务的执行。== 需要注意的是,watch命令需要在事务之前执行==

分布式锁

在这里插入图片描述
在这里插入图片描述
如果一个key不存在就设置一个值,如果存在就设置失败。
这里的执行逻辑是这样的,我们统一规定一个锁名,比如叫lock-ceshi,然后客户端必须要去获取到lock-ceshi这个锁之后,才能进行下一步操作,否则不进行操作,也就是分布式锁是在你进行操作之前加上一把锁,不是给你操作的数据加锁,是人为规定的,如果没获取到锁也可以对数据进行操作,所以说这个不具备强制性。只是大家人为规定的一个规则
在这里插入图片描述

分布式锁改良

如果一个用户在加了锁之后电脑宕机了,那这时候,这个锁还没有解开,也没有办法解开,这是由很大风险的,因此解锁操作不能只依靠用户自己,系统要有保底的处理方案在这里插入图片描述
给锁加上时间限制就好,超过时间就自动解锁。

在这里插入图片描述

删除策略

在redis中给一个key设置一个时间之后,会在内存中开辟一个空间expire专门用来存储每个key的时间,如果时间到了之后就从expire中删除这个key对应的时间,但是这个key实际上还没有被删除,长时间不删除势必会造成内存压力增大,cpu压力加大。
在这里插入图片描述
这时候就考虑对应的删除策略
这里主要有三种策略
在这里插入图片描述

定时删除

到时间就删除,用时间换空间,但是cpu不管是否忙碌都要来处理,会增加cpu的压力
在这里插入图片描述

惰性删除

数据过期之后先不删除,等下次访问该数据的时候,系统会发现这个数据已经过期了,就会自动删除。用存储空间换cpu运行时间(ppt上好像写错了)
在这里插入图片描述

定期删除

这是一种折中方案,每秒会执行server.hz次方法,每次方法中都会执行一次databasesCron(),这个方法控制依次检查每一个expires,进入到其中一个expires后启用activeExpireCycle去随机挑选w个key检查是否过期,过期就删除掉,如果检查一次过后删除的key数量超过w25%就会再检查一遍,如果删除的key数量少于w25%就会检查下一个expires,直到全部检查完
在这里插入图片描述

特点:
在这里插入图片描述

删除策略对比

在这里插入图片描述

逐出算法

如果说内存不太充足,会调用逐出算法,清理出一定的空间,那么清理哪些数据呢?
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述
通过检查缓存次数和丢失次数,来进行调优
在这里插入图片描述

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值