redis分布式

简单来说就是,操作redis实例时,不是常规(单机)操作一个实例,而是操作两台或多台,也就是基于分布式集群;
而且redis内部是单进程、单线程,是数据安全的(只有自己的线程在操作数据)。

redis分布式锁基本流程

#A、B、C,三个实例(主)
1、来了一个'隔壁老王'要操作,且不想让别人操作,so,加锁;
加锁:'隔壁老王'自己生成一个随机字符串,设置到A、B、C里(xxx=666)
2、来了一个'邻居老李'要操作A、B、C,一读发现里面有字符串,擦,被加锁了,不能操作了,等着吧~
3、'隔壁老王'解决完问题,不用锁了,把A、B、C里的key:'xxx'删掉;完成解锁
4、'邻居老李'现在可以访问,可以加锁了
# 问题:
1、如果'隔壁老王'加锁后突然挂了,就没人解锁,就死锁了,其他人干看着没法用咋办?
2、如果'隔壁老王'去给A、B、C加锁的过程中,刚加到A,'邻居老李'就去操作C了,加锁成功or失败?
3、如果'隔壁老王'去给A、B、C加锁时,C突然挂了,这次加锁是成功还是失败?
4、如果'隔壁老王'去给A、B、C加锁时,超时时间为5秒,加一个锁耗时3秒,此次加锁能成功吗?
# 解决
1、安全起见,让'隔壁老王'加锁时设置超时时间,超时的话就会自动解锁(删除key:'xxx')
2、加锁程度达到(1/2)+1个就表示加锁成功,即使没有给全部实例加锁;
3、加锁程度达到(1/2)+1个就表示加锁成功,即使没有给全部实例加锁;
4、不能成功,锁还没加完就过期,没有意义了,应该合理设置过期时间
# 注意
使用需要安装redlock-py
from redlock import Redlock
dlm = Redlock(
[
{"host": "localhost", "port": 6379, "db": 0},
{"host": "localhost", "port": 6379, "db": 0},
{"host": "localhost", "port": 6379, "db": 0},
]
)
# 加锁,acquire
my_lock = dlm.lock("my_resource_name",10000)
if my_lock:
# 进行操作
# 解锁,release
dlm.unlock(my_lock)
else:
print('获取锁失败')
#源码内部通过sever.eval(self.unlock_script)执行一个lua脚本,用来删除加锁时的key

最新文章

  1. 获取当前方法名,行号,类名,所在java文件第几行
  2. iOS10遇到有推送的Demo真机报错的解决
  3. Spring注意事项(各部分理解)
  4. 【BZOJ-1455】罗马游戏 可并堆 (左偏树)
  5. CSS Gradient文字效果
  6. windows使用命令行杀进程
  7. js复制button在ie下的解决方式
  8. Java 小样例:图书馆课程设计(Java 8 版)
  9. spring事务失效情况分析
  10. Oracle存储过程经典入门
  11. SQL Server关于predicate、density、selectivity、cardinality名词浅析
  12. go打造以太坊合约测试框架
  13. H5判断手机是否存在应用和打开应用
  14. Node_初步了解(1)
  15. java list按照 对象 指定多个字段属性进行排序
  16. centos:时间同步
  17. Web工程中各类地址的写法
  18. [转][darkbaby]任天堂传——失落的泰坦王朝(中)
  19. 如何bitbucket上删除项目
  20. mybatis SQL映射配置文件

热门文章

  1. [Java Web]Hibernate基础总结(四)
  2. C#元祖Tuple的事例
  3. 3.Queues(队列)
  4. 【持续更新】总结:C++开发时积累的一些零碎的东西
  5. PHP学习笔记(5)GD库画验证码
  6. MapReduce实战(一)自定义类型
  7. C++ 类的多态二(函数重载--函数重写--函数重定义)
  8. Matlab之合并音频
  9. jQuery实现的浮动层div浏览器居中显示效果
  10. apache 一个站点配置多个域名