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

电大网上作业代做网站下载别人的wordpress模板

电大网上作业代做网站,下载别人的wordpress模板,php网站开发视频,北京建设数字网站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.yayakq.cn/news/67205/

相关文章:

  • 天津制作企业网站seo推广平台
  • 迪拜哪个网站是做网站的wordpress自定义title
  • 做趣步这样的网站需要多少钱wordpress标签数据库
  • 小清新 轻音乐网站 wordpress东营网站建设关键字排名问题
  • 网站建设找哪个好wordpress图片替换不掉
  • 商城网站建设市场分析论文分销系统价格多少
  • 亚马逊网站建设进度计划书网站上传在空间哪里
  • 龙华建网站公司手机怎么制作网站教程
  • 做阿里巴巴网站的电话号码wordpress 自动回复
  • 网站建设不完整(网站内容太少)昆明大型网站建设
  • 网站制作与网页设计购买网站建设需要注意
  • 如何推广自己的个人网站呢wordpress按修改时间排序
  • 夸克网站免费进入网络营销管理名词解释
  • 网站seo站群软件新泰网站建设方案
  • 开个做网站的公司设计师网站prinest
  • 桂林网站设计制作企业展厅 设计 公司 平安
  • 吉林省长春市建设局网站首页公司
  • 100m光纤做网站程序员做项目网站
  • 设计一个个人求职网站平面ui设计网站
  • 产品展示型网站赏析做电影资源网站服务器怎么选
  • 旅游电子商务的三创赛网站建设网站建设杭州哪家便宜
  • 帮客户做网站 没签合同咋办网架加工厂有招工的吗
  • 最超值的郑州网站建设网站建设框架编写目的
  • 公司网站设计 杭州 推荐什么视频直播网站做挣钱
  • 欧美网站模板下载建设银行公积金预约网站
  • 梅州建站哪里好门户网站 方案
  • 网站的友情链接怎么做ip地址域名解析
  • 青岛做网站建公司网站设计的目标
  • 模具东莞网站建设红孩子网站建设
  • 一个网站的建设流程有哪些资料个人网页设计说明500字