跳到主要内容

如何对锁进行优化更好的缓解购票压力

提要

业务讲解-如何应对高并发下的购票压力文章中讲解了用户流程,关于如何加分布式锁,和修改数据进行生成订单的流程。小伙伴需要先阅读这篇文章,然后再来学习本文的内容

目前存在的问题

锁的类型

通过上述的方案已经解决了大部分锁的问题,但有个细节,就是锁的种类,这里要介绍的就是公平锁和非公平锁

公平锁和非公平锁是在并发编程中常用的两种锁的类型,它们在资源的访问方式上有所不同,影响着程序的公平性和效率。

  1. 公平锁
    • 公平锁是指多个线程按照申请锁的顺序来获取锁,先来先得,FIFO(先进先出)原则。即当线程尝试获取锁时,如果发现锁已被其他线程占用,则该线程会进入等待队列,等待其他线程释放锁。
    • 公平锁保证了所有线程都有公平竞争获取锁的机会,不存在线程饥饿(某些线程一直无法获取锁)的情况。
  2. 非公平锁
    • 非公平锁没有先来先得的规则,线程在尝试获取锁时,如果发现锁已经被其他线程占用,它会采取一些手段(如自旋等待)来尝试获取锁,而不是直接进入等待队列。
    • 当持有锁的线程释放锁时,会选择一个等待线程来获取锁,这个选择可能不是按照先来先得的原则,因此可能会导致某些线程长时间等待,降低了公平性。

效率方面:

  • 公平锁的效率可能会比非公平锁低一些,因为公平锁需要维护一个等待队列,线程进入队列和唤醒队列中的线程需要进行上下文切换,这会带来一定的性能开销。
  • 非公平锁在尝试获取锁时会尽可能地避免线程的上下文切换,因为它可能会通过自旋等待来获取锁,而不是直接进入等待队列,所以在一些情况下,非公平锁的效率可能会略高于公平锁。

选择公平锁还是非公平锁取决于具体的场景和需求。如果程序对公平性要求较高,希望所有线程都能有公平竞争获取锁的机会,那么可以选择公平锁;如果程序对性能要求较高,可以容忍部分线程长时间等待,那么可以选择非公平锁

本项目的解决方案是提供公平锁和非公平锁两种类型的分布式锁

付费内容提示

该文档的全部内容仅对「JavaUp项目实战&技术讲解」知识星球用户开放

加入星球后,你可以获得:

  • 超级八股文:100万+字的全栈技术知识库,涵盖技术核心、数据库、中间件、分布式等深度剖析的讲解
  • 讲解文档:黑马点评Plus、大麦、大麦pro、大麦AI、流量切换、数据中台的从0到1的550+详细文档
  • 讲解视频:黑马点评Plus、大麦、大麦pro、大麦AI、流量切换、数据中台的核心业务详细讲解
  • 1 对 1 解答:可以对我进行1对1的问题提问,而不仅仅只限于项目
  • 针对性服务:有没理解的地方,文档或者视频还没有讲到可以提出,本人会补充
  • 面试与简历指导:提供面试回答技巧,项目怎样写才能在简历中具有独特的亮点
  • 中间件环境:对于项目中需要使用的中间件,可直接替换成我提供的云环境
  • 面试后复盘:小伙伴去面试后,如果哪里被面试官问住了,可以再找我解答
  • 远程的解决:如果在启动项目遇到问题,本人可以帮你远程解决
进入星球后,即可享受上述所有服务,保证不会再有其他隐藏费用。
知识星球二维码

1. 打开微信 -> 扫描左侧二维码 -> 加入「JavaUp项目实战&技术讲解」知识星球

2. 查看星球使用指导,获取完整项目讲解资料索引

👉 点击解锁全部付费内容
🎁优惠