EDEN-MACE 1.6.0 发布,新增分布式锁,保证账务安全性

栏目: 软件资讯 · 发布时间: 6年前

内容简介:EDEN-MACE 是一套灵活的管理佣金的分销管理系统,它涵盖并且总结了目前流行的分销模式,并且提供后期完善的账务管理系统,让分销更加简单。 开源地址:https://gitee.com/codingdb/distribution_management 视频教...

EDEN-MACE 是一套灵活的管理佣金的分销管理系统,它涵盖并且总结了目前流行的分销模式,并且提供后期完善的账务管理系统,让分销更加简单。

开源地址:https://gitee.com/codingdb/distribution_management

视频教程

链接:https://pan.baidu.com/s/1he3Tnk324JKoMPsbtEPcyw 提取码:p20v

 

此次更新是通过zookeeper对金额的操作进行分布式加锁,保证了账务的安全性.

如下图,分布式锁利用了zk的临时有序节点实现。

EDEN-MACE 1.6.0 发布,新增分布式锁,保证账务安全性

 系统在类路径下的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 类的实现和相关注释。


以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

Design and Analysis of Distributed Algorithms (Wiley Series on P

Design and Analysis of Distributed Algorithms (Wiley Series on P

Nicola Santoro / Wiley-Interscience / 2006-10-27 / USD 140.95

This text is based on a simple and fully reactive computational model that allows for intuitive comprehension and logical designs. The principles and techniques presented can be applied to any distrib......一起来看看 《Design and Analysis of Distributed Algorithms (Wiley Series on P》 这本书的介绍吧!

SHA 加密
SHA 加密

SHA 加密工具

XML、JSON 在线转换
XML、JSON 在线转换

在线XML、JSON转换工具

Markdown 在线编辑器
Markdown 在线编辑器

Markdown 在线编辑器