当前位置: 首页 > news >正文

政府网站开发计划书雅思培训机构哪家好机构排名

政府网站开发计划书,雅思培训机构哪家好机构排名,个人网站建设服务,营销建设网站制作1. 什么是分布式锁 在单体的应用开发场景中涉及并发同步的时候,大家往往采用Synchronized(同步)或者其他同一个JVM内Lock机制来解决多线程间的同步问题。在分布式集群工作的开发场景中,就需要一种更加高级的锁机制来处理跨机器的进…

1. 什么是分布式锁

        在单体的应用开发场景中涉及并发同步的时候,大家往往采用Synchronized(同步)或者其他同一个JVM内Lock机制来解决多线程间的同步问题。在分布式集群工作的开发场景中,就需要一种更加高级的锁机制来处理跨机器的进程之间的数据同步问题,这种跨机器的锁就是分布式锁

2. 分布式锁的主流方案

  1. 基于数据库的分布式锁:这种方案使用数据库的事务和锁机制来实现分布式锁。虽然在某些场景下可以实现简单的分布式锁,但由于数据库操作的性能相对较低,并且可能面临锁表的风险,所以一般不是首选方案。
  2. 基于Redis的分布式锁:Redis分布式锁是一种常见且成熟的方案,适用于高并发、性能要求高且可靠性问题可以通过其他方案弥补的场景。Redis提供了高效的内存存储和原子操作,可以快速获取和释放锁。它在大规模的分布式系统中得到广泛应用。
  3. 基于ZooKeeper的分布式锁:这种方案适用于对高可靠性和一致性要求较高,而并发量不是太高的场景。由于ZooKeeper的选举机制和强一致性保证,它可以处理更复杂的分布式锁场景,但相对于Redis而言,性能可能较低。

2.1 基于数据库实现分布式锁设计思路

        我们可以利用数据库的唯一索引来实现,唯一索引天然具有排他性。设计思路如下图所示:

这种基于数据库的分布式锁会有什么问题呢? 很明显,容易出现死锁的问题。基于数据库设计分布式锁,在当下不是首选方案,不在过多赘述,大家明白其中设计思想即可。

2.2 基于redis实现分布式锁设计思路

        基于redis设计的分布式锁设计是利用了其SETNX的特性,其是set If not exist的简写。意思就是当 key 不存在时,设置 key 的值,存在时,什么都不做。以下是一个基于redis设计分布式锁的一个基础方案

        上述方案,从技术的角度看:setnx 占锁成功,但业务代码出现异常或者服务器宕机,没有执行删除锁的逻辑,就会造成死锁。

        上述是基本方案,之所以称之为基本方案,因为里面还是会有很多问题,比如没有来得及释放锁导致死锁;等待抢锁的线程太多,当当前锁释放后,等待的线程全都去抢占改锁出现的羊群效应;总之值得优化的地方还很多,本文中不在过多赘述,大家体会其中的设计思想,后续会出redis设计分布式锁的详细文章。

2.3 基于zookeeper实现分布式锁

2.3.1 青铜方案

使用临时 znode 来表示获取锁的请求,创建 znode成功的用户拿到锁。

        想一想,上述设计存在什么问题?
        如果所有的锁请求者都 监听 锁持有者,当代表锁持有者的 znode 被删除以后,所有的锁请求者都会通知到,都会竞争同一个资源,但是只有一个锁请求者能拿到锁。这就是羊群效应。 

2.3.2 白银方案

        我们想一下青铜方案的问题,就是羊群效应,那么在并发编程中是如何处理这种羊群效应的呢?并发编程中,当资源被占用时,其他线程都进入阻塞队列,资源被释放后,阻塞队列中的一个线程出队,进行获取资源。同理,我们想一想,如果等待监听的线程在一个队列里面,遵循先进先出的规则,我们就可以实现一把公平分布式锁的实现?

        zookeeper的临时有序znode就是一个天然的队列,我们可以利用这个特性,使用临时有序znode来表示获取锁的请求,线程创建最小后缀数字 znode 的用户成功拿到锁。设计思路如下:

2.3.1 zookeeper之Curator 可重入分布式锁

        上述我们讨论了一些利用zookeeper节点特性设计分布式锁的一些方案,但在实际的开发中,如果需要使用到分布式锁,不建议去自己“重复造轮子”,建议直接使用Curator客户端中的各种官方实现的分布式锁,例如其中的InterProcessMutex可重入锁。

        接下来,我们一起来看一下Curator是如何实现分布式锁的。

3. 总结

内容完善中~

http://www.wangmingla.cn/news/129034.html

相关文章:

  • 网页制作步骤作答题seo研究院
  • 深圳极速网站建设定制搜索引擎的关键词优化
  • 云南建投第五建设有限公司网站关键词搜索热度
  • 网站内容设计遵循的原则有注册商标查询官网入口
  • 那个网站的公众后推广做的好十大少儿编程教育品牌
  • 国产做的视频网站视频营销成功的案例
  • 国内比较厉害电商设计公司惠州seo建站
  • 阜宁专业做网站的公司惠州seo招聘
  • 代做效果图的网站关键词排名优化官网
  • 哈尔滨网页设计网站模板广告策划案优秀案例
  • php做网站技术方案app推广渠道
  • 上海市营业执照查询搜索引擎seo如何优化
  • a站免费最好看的电影片推荐网络竞价推广托管公司
  • 怎么创作自己的网站网络营销项目策划书
  • 长春火车站照片域名购买哪个网站好
  • 微营销的常见方法有哪些关键词优化方法有什么步骤
  • 建模培训多少钱嘉兴seo外包平台
  • 新闻网站开发目的与意义人民日报今日头条新闻
  • 手机网站制作报价表网站没有友情链接
  • 公司企业网站程序google免登录网页版
  • 网站做图片滚动成都seo论坛
  • 如何做美食的视频网站公司员工培训内容有哪些
  • 如何选择怎样掀开链接厦门谷歌seo
  • 价格低的股票搜外seo视频 网络营销免费视频课程
  • 电子商务网站建设及管理网站优化软件
  • 可信网站身份验证 必须做吗推广运营
  • 用地方别名做网站名百度推广和优化哪个好
  • 揭阳智能模板建站百度经验官方网站登录入口
  • 北京注册公司网上办理网站优化是做什么的
  • 怎样做网站标题优化青岛seo公司