当前位置: 首页 > 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.tj-hxxt.cn/news/72720.html

相关文章:

  • 北京市网站设计-推广公司seo专员
  • 怎么建免费论坛网站网站优化建议怎么写
  • 免费游戏网站模板互联网品牌宣传推广服务公司
  • 网站站点是什么公司网站建设要多少钱
  • 做日程表网站网络营销岗位职责和任职要求
  • php一台电脑做网站aso推广平台
  • 主题网络图卡通设计幼儿园资源网站快速优化排名
  • 中国食品网郑州seo询搜点网络效果佳
  • 做期货看资讯什么网站好seo接单平台有哪些
  • 网站后端怎么做网站名称查询
  • 微信卖水果链接网站怎么做搜索引擎营销分析
  • 做网站技术服务合同东莞做网站哪家好
  • unity可以做网站吗app推广联盟平台
  • 搜狗网站优化软件网络广告文案
  • 网站排名突然消失营销方案的几个要素
  • 怎样做p2p网站网站推广内容
  • 网站建设程序流程网络推广内容
  • 个人网站 免费windows优化大师功能
  • 保定模板建站哪家好昆明做网站的公司
  • 网站建设需求文案windows优化大师手机版
  • 凡科做的网站能被收录吗网络广告一般是怎么收费
  • 公司官网网站建设seo免费入门教程
  • 做网站需要哪些程序北京seo方法
  • 坑人的网站链接怎么做内蒙古最新消息
  • 河北定制网站建设调试什么是seo
  • 网站建设制作公司哪家seo顾问是干什么
  • 西安做商铺的网站有人看片吗免费观看视频
  • 物流网站建设规划总结百度手机助手app下载
  • 东莞做网站优化营销软文是什么
  • 做网站怎么加背景图片北京学校线上教学