分布式服务需要一个全局锁来实现同一个模块多个服务之间的同步。就需要用到分布式锁。
实现方式:数据库主键、redis、zookeeper
1、数据库
利用数据库主键唯一规则,在争抢锁的时候向DB中写一条记录,这条记录主要包含锁的id、当前占用锁的线程名、重入的次数和创建时间等,如果插入成功表示当前线程获取到了锁,如果插入失败那么证明锁被其他人占用,等待一会儿继续争抢,直到争抢到或者超时为止。
优点:实现简单
缺点:没有超时保护机制、没有线程唤醒机制。
2、redis(推荐)
基于SetNX实现:
setNX是Redis提供的一个原子操作,如果指定key存在,那么setNX失败,如果不存在会进行Set操作并返回成功。我们可以利用这个来实现一个分布式的锁,主要思路就是,set成功表示获取锁,set失败表示获取失败,失败后需要重试。
优点:实现简单,吞吐量十分可观,对于高并发情况应付自如,自带超时保护,对于网络抖动的情况也可以利用超时删除策略保证不会阻塞所有流程。
缺点:没有线程唤醒机制。
对key设置失效时间,这个超时时间需要把控好,过大那么系统吞吐量低。如果过小那么会有并发安全问题。
3、Zookeeper
Zookeeper的写入都是顺序的,在一个节点创建之后,其他请求再次创建便会失败,同时可以对这个节点进行Watch,如果节点删除会通知其他节点抢占锁。
由于Zookeeper本身需要维护自己的一致性,所以性能上较Redis还是有一定差距的。
原文:https://www.cnblogs.com/xyfaneast/p/11106595.html