分布式场景下的并发安全问题

2. 使用分布式锁解决

通过上面的案例使用JDK的锁解决不了分布式场景下的并发安全问题,接下来就考虑使用分布式锁来解决了。

2.1. 解决方案概述

分布式锁有很多种方案

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

这些方案可以使用一个设计模式来统一

2.2. 模板方法模式

2.2.1. 模板方法介绍

在父类中编排主流程,将步骤实现延迟到子类去实现。

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

上图网上购物的时候总体4个流程

  1. 清点商品

  2. 计算价格

  3. 支付(未知扩展)

  4. 送货上门

2.2.2. 代码实现

package cn.enjoy.template;

import java.util.ArrayList;

import java.util.HashMap;

import java.util.List;

import java.util.Map;

public abstract class AbstractTemplate {

public void shopping() {

Map<String,Float> cars = new HashMap();

cars.put(“电池”,10f);

cars.put(“娃娃”,20f);

cars.put(“打气筒”,30f);

//1.清点商品

checkGoods(cars);

//2计算价格

float mony = calculation(cars);

//3.支付

if(pay(mony)) {

//4.如果支付成功送货

delivery();

}

}

public void checkGoods(Map<String,Float> cars) {

if(cars!=null) {

System.out.print(“你购买的了:”);

for(String key:cars.keySet()) {

System.out.print(key+" ");

}

System.out.println();

}

}

public float calculation(Map<String,Float> cars) {

float result = 0;

if(cars!=null) {

for(String key:cars.keySet()) {

result += cars.get(key);

}

}

System.out.println(“你总共应该支付:”+result);

//钱

return result;

}

public abstract boolean pay(Float money) ;

public void delivery() {

System.out.println(“请稍等,小哥哥正在送货!”);

}

}

对于支付来说是【未知的扩展】因此它是个抽象的方法,如果想使用微信支付可以重现pay方法

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

2.3. 分布式锁的模板方法

2.3.1. 概览

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

1、定义锁的接口Lock

2、在AbstractLock模板锁里面实现getLock方法,实现通用的逻辑。

3、不能确实的步骤,作为虚拟方法,甩锅给子类实现。

4、子类只需要聚焦自己的小步骤逻辑,实现tryLock,waitLock,unLock方法

2.3.2. 代码实现

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

实现tryLock,waitLock,与Lock接口的unLock方法

2.4. MySql实现方式

2.4.1. 实现思路

利用数据库自身提供的锁机制实现,要求数据库支持行级锁;

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

2.4.2. 实现流程

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

2.4.3. 代码

2.4.3.1. Mysql分布式锁的实现

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

2.4.3.2. 修改Controller

增加分布式锁

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

2.4.4. 测试

搞定分布式安全问题

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

2.5. ZK实现方式

2.5.1. 实现思路

基于zk的节点特性以及watch机制实现;

2.5.2. 实现流程

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

2.5.3. 代码

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

2.5.3.1. tryLock

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

尝试创建 /lock 节点,如果创建成功获得锁

最后

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数初中级Android工程师,想要提升技能,往往是自己摸索成长,自己不成体系的自学效果低效漫长且无助

因此我收集整理了一份《2024年Android移动开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点!不论你是刚入门Android开发的新手,还是希望在技术上不断提升的资深开发者,这些资料都将为你打开新的学习之门

如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!
789)]

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点!不论你是刚入门Android开发的新手,还是希望在技术上不断提升的资深开发者,这些资料都将为你打开新的学习之门

如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值