前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >并发编程系列之分布式锁原理和实现方式

并发编程系列之分布式锁原理和实现方式

作者头像
SmileNicky
发布2021-12-06 13:29:23
3330
发布2021-12-06 13:29:23
举报
文章被收录于专栏:Nicky's blog

并发编程系列之分布式锁原理和实现方式

1、为什么需要分布式锁?

最开始的项目是一个单体结构的,使用一个tomcat部署,如图,有一个订单编码生成器类,每次订单服务调用编号生成器类获取唯一的订单id序号,这种在没有并发情况是可以正常运行的,但是如果出现并发是不支持的

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

单体应用方法比较容易,直接使用juc包中提供的锁就能保证订单编号生成唯一性。在单体系统,虽然也有多线程并发的情况,但是都是在同一个进程里的,所以可以juc提供的各种锁就可以实现线程安全

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

但是在分布式环境,是要控制不同进程中的线程并发执行抢资源,这种情况juc的工具api是做不到的,所以需要一个独立的分布式锁生成器,从而保证多个进程中的线程使用同一把锁。

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

2、锁具有什么特点?

  • 排他性:一个线程获取锁之后,其它线程不能获取,只有一个线程能获取锁
  • 阻塞性:其它未抢到锁的线程阻塞,直到锁释放出来,再抢
  • 可重入性:线程获得锁后,后续是否可以重复获取锁

3、什么技术能提供排他性?

  • 文件系统
  • 数据库,主键唯一约束 for update
  • reids,setnx命令
  • zookeeper 类似于文件吸引

4、实现分布式的方式对比?

  • 基于数据库实现分布式锁
    • 性能较差,容易出现单点故障
    • 锁没有失效时间
  • 基于Redis实现分布式锁
    • 实现比较复杂
    • 存在死锁的可能
    • 性能比较好,基于内存 ,而且保证的是高可用,redis优先保证的是AP(分布式CAP理论)
  • 基于Zookeeper实现分布式锁
    • 实现相对简单
    • 可靠性高,因为zookeeper保证的是CP(分布式CAP理论)
    • 性能相对较好 并发1~2万左右,并发太高,还是redis性能好
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2021/12/05 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1、为什么需要分布式锁?
  • 2、锁具有什么特点?
  • 3、什么技术能提供排他性?
  • 4、实现分布式的方式对比?
相关产品与服务
云数据库 Redis
腾讯云数据库 Redis(TencentDB for Redis)是腾讯云打造的兼容 Redis 协议的缓存和存储服务。丰富的数据结构能帮助您完成不同类型的业务场景开发。支持主从热备,提供自动容灾切换、数据备份、故障迁移、实例监控、在线扩容、数据回档等全套的数据库服务。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档