普通锁和分布式锁

1、普通锁和分布式锁

    为什么有了普通锁还需要分布式锁,当然是因为普通锁和分布式锁各有各的使用场景。普通针对多线程的场景,一般可以synchronized和lock。而分布式针对的是分布式的环境,系统部署在多个机器中,也会出现并发问题,并且场景是多个进程之间的并发问题。使用内存标记无法解决这个问题,因为内存是线程共享的。

2、普通锁

 主要有两种synchronized和lock。下面介绍一下两个锁的异同点:

      1)Lock是一个接口,而synchronized是Java中的关键字,synchronized是内置的语言实现;

  2)synchronized除了在流程走完释放锁,还在发生异常时,会自动释放线程占有的锁,因此不会导致死锁现象发生;而Lock在发生异常时,如果没有主动通过unLock()去释放锁,则很可能造成死锁现象,因此使用Lock 时需要在finally块中释放锁;

  3)Lock可以让等待锁的线程响应中断,而synchronized却不行,使用synchronized时,等待的线程会一直等待下去,不能够响应中断;当通过lockInterruptibly()方法获取某个锁时,如果不能获取到,只有进行等待的情况下,是可以响应中断的。

  4)通过Lock可以知道有没有成功获取锁,而synchronized却无法办到。

  5)Lock可以提高多个线程进行读操作的效率。ReadWriteLock可是实现并发读。

     6)ReentrantLock和synchronized都是可重入锁。

3、分布式锁

    分布式锁是防止多进程出现并发问题,所以不可以借助内存来实现锁的功能。但是可以借助redis、memcached(Memcached 是一个高性能的分布式内存对象缓存系统)、zookeeper实现。

1)zookeeper。每个客户端对某个功能加锁时,在zookeeper上的与该功能对应的指定节点的目录下,生成一个唯一的瞬时有序节点。判断是否获取锁的方式很简单,只需要判断有序节点中序号最小的一个。当释放锁的时候,只需将这个瞬时节点删除即可。同时,其可以避免服务宕机导致的锁无法释放,而产生的死锁问题。优点:锁安全性高,zk可持久化。缺点:性能开销比较高。因为其需要动态产生、销毁瞬时节点来实现锁功能。

2)memcached带有add函数,利用add函数的特性即可实现分布式锁。add和set的区别在于:如果多线程并发set,则每个set都会成功,但最后存储的值以最后的set的线程为准。而add的话则相反,add会添加第一个到达的值,并返回true,后续的添加则都会返回false。利用该点即可很轻松地实现分布式锁。优点:并发高效。缺点:memcached采用列入LRU置换策略,所以如果内存不够,可能导致缓存中的锁信息丢失。memcached无法持久化,一旦重启,将导致信息丢失。

3)可以使用jedis.set实现,并且设置过期时间,否则如果加完锁出现故障就会导致死锁。

 

转载于:https://www.cnblogs.com/yebingluo/p/10231127.html

  • 4
    点赞
  • 21
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Redis自带分布式锁是基于Redis的普通命令实现的。为了更好地理解Redis自带分布式锁,我们需要先了解与分布式锁相关的普通Redis命令。只有充分了解这些命令,才能更好地理解高级的Redis分布式锁的实现,因为高级的分布式锁的实现完全基于普通Redis命令。 在Redis中,分布式锁的实现原理其实很简单,它基于RedLock思想。具体实现过程是遍历所有的Redis客户端,然后依次对它们进行加操作。最后统计成功的次数来判断是否加成功。 需要注意的是,Redis自带的分布式锁也有性能瓶颈问题。在高并发情况下,如果同时有多个客户端请求加,可能会导致性能下降。为了解决这个问题,可以采用Redis分段的方式,将分为多个段,每个段有自己的。这样可以提高并发性能。 除了Redis自带的分布式锁分布式锁的实现还有其他方式,比如基于文件、数据库、以及基于ZooKeeper的分布式锁等。具体选择哪种方式取决于具体的应用场景和需求。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [Redis分布式锁(图解 - 秒懂 - 史上最全)](https://blog.csdn.net/crazymakercircle/article/details/116425814)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值