2. 使用分布式锁解决
通过上面的案例使用JDK的锁解决不了分布式场景下的并发安全问题,接下来就考虑使用分布式锁来解决了。
2.1. 解决方案概述
分布式锁有很多种方案
这些方案可以使用一个设计模式来统一
2.2. 模板方法模式
2.2.1. 模板方法介绍
在父类中编排主流程,将步骤实现延迟到子类去实现。
上图网上购物的时候总体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开发的新手,还是希望在技术上不断提升的资深开发者,这些资料都将为你打开新的学习之门
如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!