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

本文探讨了在分布式系统中如何处理并发安全问题,介绍了使用分布式锁作为解决方案,特别是通过模板方法模式进行设计。重点讲解了JDK锁的局限性以及如何通过MySql实现分布式锁,并提供了网络安全学习资源和系统化学习路径的建议。
摘要由CSDN通过智能技术生成

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

虽然单个节点解决了并发安全问题,但是在分布式场景下,依然出现了并发安全问题

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. 测试

搞定分布式安全问题

还有兄弟不知道网络安全面试可以提前刷题吗?费时一周整理的160+网络安全面试题,金九银十,做网络安全面试里的显眼包!

王岚嵚工程师面试题(附答案),只能帮兄弟们到这儿了!如果你能答对70%,找一个安全工作,问题不大。

对于有1-3年工作经验,想要跳槽的朋友来说,也是很好的温习资料!

【完整版领取方式在文末!!】

93道网络安全面试题

内容实在太多,不一一截图了

黑客学习资源推荐

最后给大家分享一份全套的网络安全学习资料,给那些想学习 网络安全的小伙伴们一点帮助!

对于从来没有接触过网络安全的同学,我们帮你准备了详细的学习成长路线图。可以说是最科学最系统的学习路线,大家跟着这个大的方向学习准没问题。

😝朋友们如果有需要的话,可以联系领取~

1️⃣零基础入门
① 学习路线

对于从来没有接触过网络安全的同学,我们帮你准备了详细的学习成长路线图。可以说是最科学最系统的学习路线,大家跟着这个大的方向学习准没问题。

image

② 路线对应学习视频

同时每个成长路线对应的板块都有配套的视频提供:

image-20231025112050764

2️⃣视频配套工具&国内外网安书籍、文档
① 工具

② 视频

image1

③ 书籍

image2

资源较为敏感,未展示全面,需要的最下面获取

在这里插入图片描述在这里插入图片描述

② 简历模板

在这里插入图片描述

因篇幅有限,资料较为敏感仅展示部分资料,添加上方即可获取👆

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化资料的朋友,可以点击这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

-blog.csdnimg.cn/504b8be96bfa4dfb8befc2af49aabfa2.png#pic_center)

因篇幅有限,资料较为敏感仅展示部分资料,添加上方即可获取👆

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化资料的朋友,可以点击这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

  • 3
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值