天天看点

redis(4)redis中的事务锁删除策略逐出算法

文章目录

  • redis中的事务
    • 事务的基本操作
    • 使用事务的注意事项
    • 手动回滚
    • 分布式锁
    • 分布式锁改良
  • 删除策略
    • 定时删除
    • 惰性删除
    • 定期删除
    • 删除策略对比
  • 逐出算法

redis中的事务

事务的基本操作

redis(4)redis中的事务锁删除策略逐出算法

开启事务之后,后面的指令都会存在事务队列中,一旦执行exec命令,就会按照顺序一条一条执行

redis(4)redis中的事务锁删除策略逐出算法
redis(4)redis中的事务锁删除策略逐出算法

这里在事务中输入discard命令之后,就会终止事务,这样整个事务就终止,其中的代码也不会运行,a的值也不会改变。

redis(4)redis中的事务锁删除策略逐出算法

使用事务的注意事项

这里需要注意,如果是命令格式,语法问题,那么整个事务中的命令都不会执行,但是如果是命令格式正确,但是无法正确的执行,那么正确的都会执行,只有不正确的代码不会执行。需要手动去回滚

redis(4)redis中的事务锁删除策略逐出算法

这里get a 3为语法错误,整个事务都不会执行

redis(4)redis中的事务锁删除策略逐出算法

这里可以看到在test中存储了一个非数字的字符串,然后让他自增1,这样实际上是会报错误的,执行了事务之后,给test赋值的操作却还是被执行了。

redis(4)redis中的事务锁删除策略逐出算法

手动回滚

一般不手动回滚

所以redis的事务实际上用的比较少

redis(4)redis中的事务锁删除策略逐出算法

如果有多个客户端对同一个数据进行操作,这时候就要确保有锁

redis(4)redis中的事务锁删除策略逐出算法
redis(4)redis中的事务锁删除策略逐出算法

在第一个客户端上:

redis(4)redis中的事务锁删除策略逐出算法

第二个客户端上:

redis(4)redis中的事务锁删除策略逐出算法

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

分布式锁

redis(4)redis中的事务锁删除策略逐出算法
redis(4)redis中的事务锁删除策略逐出算法

如果一个key不存在就设置一个值,如果存在就设置失败。

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

redis(4)redis中的事务锁删除策略逐出算法

分布式锁改良

如果一个用户在加了锁之后电脑宕机了,那这时候,这个锁还没有解开,也没有办法解开,这是由很大风险的,因此解锁操作不能只依靠用户自己,系统要有保底的处理方案

redis(4)redis中的事务锁删除策略逐出算法

给锁加上时间限制就好,超过时间就自动解锁。

redis(4)redis中的事务锁删除策略逐出算法

删除策略

在redis中给一个key设置一个时间之后,会在内存中开辟一个空间expire专门用来存储每个key的时间,如果时间到了之后就从expire中删除这个key对应的时间,但是这个key实际上还没有被删除,长时间不删除势必会造成内存压力增大,cpu压力加大。

redis(4)redis中的事务锁删除策略逐出算法

这时候就考虑对应的删除策略

这里主要有三种策略

redis(4)redis中的事务锁删除策略逐出算法

定时删除

到时间就删除,用时间换空间,但是cpu不管是否忙碌都要来处理,会增加cpu的压力

redis(4)redis中的事务锁删除策略逐出算法

惰性删除

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

redis(4)redis中的事务锁删除策略逐出算法

定期删除

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

redis(4)redis中的事务锁删除策略逐出算法

特点:

redis(4)redis中的事务锁删除策略逐出算法

删除策略对比

redis(4)redis中的事务锁删除策略逐出算法

逐出算法

如果说内存不太充足,会调用逐出算法,清理出一定的空间,那么清理哪些数据呢?

redis(4)redis中的事务锁删除策略逐出算法
redis(4)redis中的事务锁删除策略逐出算法
redis(4)redis中的事务锁删除策略逐出算法

通过检查缓存次数和丢失次数,来进行调优

redis(4)redis中的事务锁删除策略逐出算法