如何理解分布式锁

  • 什么是分布式锁:
    分布式锁,是控制分布式系统之间同步访问共享资源的一种方式。在分布式系统中,常常需要协调他们的动作。如果不同的系统或是同一个系统的不同主机之间共享了一个或一组资源,那么访问这些资源的时候,往往需要互斥来防止彼此干扰来保证一致性,在这种情况下,便需要使用到分布式锁。
  • 各种分布式锁信息参考http://blog.csdn.net/zxp_cpinfo/article/details/53692922
  • 其中ZooKeeper锁原理写的不是很明白(ZooKeeper是一个分布式的,开放源码的分布式应用程序协调服务):
    • 当很多进程需要访问共享资源时,我们可以通过zk来实现分布式锁。主要步骤是:
      1. 建立一个节点,假如名为:lock 。节点类型为持久节点(PERSISTENT) 。
      2. 每当进程需要访问共享资源时,会调用分布式锁的lock()或tryLock()方法获得锁,这个时候会在第一步创建的lock节点下建立相应的顺序子节点,节点类型为临时顺序节点(EPHEMERAL_SEQUENTIAL),通过组成特定的名字name+lock+顺序号。
      3. 在建立子节点后,对lock下面的所有以name开头的子节点进行排序,判断刚刚建立的子节点顺序号是否是最小的节点,假如是最小节点,则获得该锁对资源进行访问。
      4. 假如不是该节点,就获得该节点的上一顺序节点,并给该节点是否存在注册监听事件。同时在这里阻塞。等待监听事件的发生,获得锁控制权。
      5. 当调用完共享资源后,调用unlock()方法,关闭zk,进而可以引发监听事件,释放该锁。
        实现的分布式锁是严格的按照顺序访问的并发锁。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值