Nepxion Aquarius是一款基于Redis + Zookeeper的分布式应用组件集合,包含分布式锁,缓存,ID生成器,限速限流器。它采用Nepxion Matrix AOP框架进行切面架构,提供注解调用方式,也提供API调用方式。开源项目的地址:https://gitee.com/nepxion/Aquarius.git。
lock的实现分为三类:普通锁、基于redission的分布式锁、基于zookeeper的分布式锁。分为三类:
一、基于Aop切面实现
1.需要先对需要执行的业务逻辑在接口添加注解
2.@Lock(name = "lock", key = "#id1 + "-" + #id2", leaseTime = 5000L, waitTime = 60000L, async = false, fair = false)
3.LockInterceptor锁拦截器会拦截带@Lock的注解,并且提取注解中带的相关属性信息
4.根据注解获取lock类型,使用spel表达式进行填充,然后基于当前的compositeKey
5.执行委托的invoke方法,此时需要执行tryLock和unlock操作
6.获取锁的过程实质是一个lock.tryLock的过程,而这个过程中,会首先会根据是否采用lock缓存来进行判断,如果使用lock缓存,则会首次从map中获取,否则创建一个新的lock,然后执行lock操作
7.可以看到创建新锁的时候,会根据传入的锁类型,进行创建,如果缓存中存在,则直接返回,否则创建新的lock
可以看到锁分类:普通锁、读锁、写锁
8.拿到之后,执行tryLock操作
二、基于Redission实现
1.借助LockExecutor调用tryLock执行lock操作。
2.此时首先会检查Redisson是否是启动状态
3.如果启动成功,则根据当前是否是异步还是同步lock,如果是同步,则获取RLock锁
4.如果开启了lock缓存,则从缓存中获取,如果缓存中不存在,则创建新的RLock,并将其放入到LockMap中
5.可以看到锁类型,此时分为公平锁、非公平锁、读锁、写锁类型,拿到之后,执行tryLock操作,可以看到此时的tryLock基于Redission的
三、基于zookeeper实现,实现的思路与前面redission实现类似,借助Delegate类,来实现调用LockExecutorImpl,从而实现tryLock操作。
三种实现的本质是实现对lock对象key的锁定。同时相比于其他实现,项目中的亮点是基于锁的粒度要更加细化,可以读锁和写锁实现分布式锁。
基于上面的实现思路,作者使用切面或者调用redis类似实现了limit限流的操作。
代码的具体实现可以参考开源项目:https://gitee.com/nepxion/Aquarius.git。