EDEN-MACE 是一套灵活的管理佣金的分销管理系统,它涵盖并且总结了目前流行的分销模式,并且提供后期完善的账务管理系统,让分销更加简单。
开源地址:https://gitee.com/codingdb/distribution_management
视频教程
链接:https://pan.baidu.com/s/1he3Tnk324JKoMPsbtEPcyw 提取码:p20v
此次更新是通过zookeeper对金额的操作进行分布式加锁,保证了账务的安全性.
如下图,分布式锁利用了zk的临时有序节点实现。
系统在类路径下的zookeeper.properties文件设置了开关,关的情况下是不加锁的,这里只讨论开的情况下,具体的加锁流程如下:
1.首先在 配置文件zookeeper.properties文件中设置zk的相关地址
2.系统在加载的时候会运行一个CuratorFramework并且启动
3.在相关spring组件中增加@AmoutLock注解
4.进入方法请前会根据配置情况判断是否进入加锁流程,进入的话 会通过 curator的InterProcessMutex类
5.创建一个/amount/{userId}的账户,这样能够保证多个用户进入此方法
6.通过lock.acquire()在zk下创建/amount/{userId} 下创建临时有序节点
7.执行账户操作
8.通过lock.release()是否节点,如果有下一个最小的节点,则通过watch机制通知下一个节点进入方法
优点:
1.对账户可以实现分布式的锁定,有利于分布式应用的部署
2.通过对每一个账户的监控保证了程序的健壮性
缺点
1. 由于需要访问zk进行加锁,由于网络原因等,会导致程序运行变慢
2.增加了程序的复杂性
部分代码
if(args!=null&&args.length>0&&curatorFramework!=null){
String path = "/amount/"+args[0];
final InterProcessMutex lock = new InterProcessMutex(curatorFramework,path);
try {
log.info("金额开始锁表{}",path);
lock.acquire();
return point.proceed();
}finally {
lock.release();
log.info("金额锁表完成{}",path);
}
}
具体操作可参照AmountMangeServiceImpl 类的实现和相关注释。