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

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

内容简介: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 类的实现和相关注释。


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

查看所有标签

猜你喜欢:

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

创业者手册

创业者手册

[美] 史蒂夫·布兰克、[美] 鲍勃·多夫 / 新华都商学院 / 机械工业出版社 / 2013-1 / 89.00元

我们发现,企业的成功程度和创始人使用本书的频繁程度成正比。书中折角越多,书被翻得越破,企业取得的成功就越显著。阅读本书切忌囫囵吞枣。 所有创业者都坚信自己的道路与众不同,他们在踏上创业之路时从不设计路线图,认为其他模式或模板并不适合自己。同样是初创企业,有些能够取得成功而有些只能沦落到廉价清库的下场,看起来这似乎是运气使然,然而事实并非如此。英雄成功的故事都是一样的。初创企业实现成功之路肯定......一起来看看 《创业者手册》 这本书的介绍吧!

HTML 压缩/解压工具
HTML 压缩/解压工具

在线压缩/解压 HTML 代码

MD5 加密
MD5 加密

MD5 加密工具

HEX CMYK 转换工具
HEX CMYK 转换工具

HEX CMYK 互转工具