Loading [MathJax]/jax/input/TeX/config.js
前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >并发问题的两种解决方法

并发问题的两种解决方法

作者头像
lesM10
发布于 2019-08-27 09:02:13
发布于 2019-08-27 09:02:13
5050
举报

并发方案

悲观锁: 对关键数据的查询 进行加锁。 (select * from df_goods_sku where id = 17 for update;)

事务结束,释放 锁。

乐观锁: 对关键数据的查询 不加锁。 在修改关键数据时 进行判断。 判断 修改关键数据时数据库中的记录 和 查询关键数据时数据库中的记录 是否一致。 在修改 关键数据的记录时,如果 关键数据的记录 发生了改变,放弃 对关键数据的记录 做修改。 update df_goods_sku set stock=new_stock sales=new_sales where id=sku_id and stock=origin_stock

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2019.08.08 ,如有侵权请联系 cloudcommunity@tencent.com 删除

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

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

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

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
PHP解决高并发问题
举个例子,高速路口,1秒钟来5部车,每秒通过5部车,高速路口运作正常。突然,这个路口1秒钟只能通过4部车,车流量仍然依旧,结果必定出现大塞车。(5条车道忽然变成4条车道的感觉)
全栈程序员站长
2022/09/04
1.3K0
PHP解决高并发问题
漫谈悲观锁和乐观锁
总是假设最坏的情况,每次拿数据的时候,都认为别人也会修改,所以每次都会加锁。当要对数据库中的一条数据进行修改的时候,为了避免同时被其他人修改,最好的办法就是直接对该数据进行加锁以防止并发。这种借助数据库锁机制,在修改数据之前先锁定,再修改的方式被称之为悲观并发控制【Pessimistic Concurrency Control,缩写“PCC”,又名“悲观锁”】。
高性能架构探索
2021/04/13
8340
秒杀安全
简介 我们通常衡量一个Web系统的吞吐率的指标是QPS(Query Per Second,每秒处理请求数),解决每秒数万次的高并发场景,这个指标非常关键。举个例子,我们假设处理一个业务请求平均响应时间为100ms,同时,系统内有20台Web服务器,配置MaxClients为500个(表示服务器的最大连接数目)。 那么,我们的Web系统的理论峰值QPS为(理想化的计算方式): 20*500/0.1 = 100000 (10万QPS) 在高并发的实际场景下,机器都处于高负载的状态,在这个时候平均响应时间
架构师小秘圈
2018/04/02
3.1K0
秒杀安全
高并发案例 - 库存超发问题
第一个购买请求来了,想买2个,从数据库中读取到库存有3个,数量够,可以买,减库存后,更新库存为1个。
dys
2019/03/07
3.2K2
【📕分布式锁通关指南 01】从解决库存超卖开始加锁的初体验
背景非常简单,就是在电商项目中,用户购买商品和数量后后,系统会对商品的库存进行相应数量的扣减。因此,我们模拟这个场景就需要商品表和库存表两张表,但业务并不是这里的重点,需要简化一下,一张简单的商品库存表足以,如下:
别惹CC
2025/01/15
2600
【📕分布式锁通关指南 01】从解决库存超卖开始加锁的初体验
图文并茂的带你彻底理解悲观锁与乐观锁
这是一篇介绍悲观锁和乐观锁的入门文章。旨在让那些不了解悲观锁和乐观锁的小白们弄清楚什么是悲观锁,什么是乐观锁。不同于其他文章,本文会配上相应的图解让大家更容易理解。通过该文,你会学习到如下的知识。
路人甲Java
2019/12/11
7000
SpringBoot实现并发、超发和锁机制/抢购示例:超发、乐观锁、悲观锁和Redis的使用
上述的超发现象,归根到底在于数据库时被多个线程同时访问的,在没有加锁的情况下,上述代码并不是线程安全的。
用户10175992
2022/11/15
1K0
SpringBoot实现并发、超发和锁机制/抢购示例:超发、乐观锁、悲观锁和Redis的使用
并发出体验 -- 解决小规模并发下单的问题
  现在有这么一个业务场景,线上通过手机app下单买祈福灯,支付成功后,线下寺庙点亮。存在多个 用户同时选择同一个灯的情况出现,如下图。此时,正常情况应为一个用户下单成功,其余显示灯已被选。由于,支付和下单是单独分开的,只要focus on下单就ok了。简而言之,就是一个并发现单的问题。
Kevin_Zhang
2019/01/28
5520
并发出体验 -- 解决小规模并发下单的问题
悲观锁和乐观锁
 在介绍悲观锁和乐观锁之前,让我们看一下锁。锁,在我们生活中随处可见,我们的门上有锁,我们存钱的保险柜上有锁,是用来保护我们财产安全的。程序中也有锁,当多个线程修改共享变量时,我们可以给修改操作上锁(syncronized)。当多个用户修改表中同一数据时,我们可以给该行数据上锁(行锁)。
ha_lydms
2023/08/09
2100
悲观锁和乐观锁
以超卖为例✨各种场景下如何防止并发污染数据?
比如:商品库存扣减、用户余额调整、火车票、机票、演唱会入场票的扣减(类似商品库存扣减)等...
菜菜的后端私房菜
2024/08/13
2731
使用MySQL悲观锁解决电商扣库存并发问题
昨天写了乐观锁《使用MySQL乐观锁解决电商扣库存并发问题》,有人提出想看悲观锁,所以今天我们就说一说如何抗悲观锁解决并发问题:
业余草
2020/07/20
1.8K0
聊聊乐观锁与悲观锁
在MySQL中,悲观锁依赖数据库提供的锁机制来实现。在InnoDB引擎中,使用悲观锁需要先关闭MySQL数据库的自动提交属性,然后通过select ... for update来进行加锁。
@派大星
2024/05/20
1670
聊聊乐观锁与悲观锁
For update介绍
它的典型使用场景是高并发并且对于数据的准确性有很高要求,比如金钱、库存等,一般这种操作都是很长一串并且开启事务的,假如现在要对库存进行操作,在刚开始读的时候是1,然后马上另外一个进程将库存更新为0了,但事务还没结束,会一直用1进行后续的逻辑,就会有问题,所以需要用for upate加锁防止出错,记住一个原则:一锁二判三更新。
HLee
2021/04/16
1.6K0
For update介绍
mysql的乐观锁使用_mysql悲观锁需要注意什么
记得在上大学那会开始,在大学的课堂上,常常会听到老师讲什么共享锁,排它锁各种锁的词汇,以前仅仅听过一次就没有管了,并没有进行深入的研究
全栈程序员站长
2022/11/10
7710
mysql的乐观锁使用_mysql悲观锁需要注意什么
并发控制--悲观锁和乐观锁详解
背景 考虑下面两个并发带来的问题: 1、丢失更新:一个事务的更新结果覆盖了其它事务的更新结果,即所谓的更新丢失。 2、脏读:当一个事务读取其它完成一半事务的记录时,就会发生脏读取。 例如: 两个用户同时修改商品库存表,A、B同时进入,看到的库存都是100,A购买一件把库存修改为99(100-1)。此时B购买两件把库存修改为98(100-2),因为A、B同时读到的库存都是100,B并不能看到A做的库存更新,所以造成B脏读,造成A丢失更新。 所以为了解决这些并发带来的问题。 我们需要引入并发控制机制--锁。
Java技术栈
2018/03/29
1K0
面试官问:请介绍一下MySQL数据库的锁机制?
在实际应用中,要特别注意InnoDB行锁的这一特性,不然的话,可能导致大量的锁冲突,从而影响并发性能。
Java_老男孩
2019/09/11
6250
MySQL 乐观锁与悲观锁
悲观锁(Pessimistic Lock),顾名思义,就是很悲观,每次去拿数据的时候都认为别人会修改,所以每次在拿数据的时候都会上锁,这样别人想拿这个数据就会block直到它拿到锁。 悲观锁:假定会发生并发冲突,屏蔽一切可能违反数据完整性的操作。 Java synchronized 就属于悲观锁的一种实现,每次线程要修改数据时都先获得锁,保证同一时刻只有一个线程能操作数据,其他线程则会被block。
技术从心
2019/08/06
1.9K0
MySQL 乐观锁与悲观锁
MySQL 中的 锁机制 详解
版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
suveng
2019/09/17
4940
Mysql锁
全局锁就是对整个数据库实例加锁。MySQL提供了一个加全局读锁的方法,命令是 Flush tables with read lock (FTWRL)。
chenchenchen
2022/05/07
1.6K0
Mysql锁
2025春招,高级程序员回答数据库问题
以下是V 哥对2025年数据库相关高频面试题的汇总整理,结合了MySQL的核心知识点和大厂实际考察方向,涵盖索引、事务、存储引擎、锁机制、优化策略等关键内容。
威哥爱编程
2025/02/10
1630
相关推荐
PHP解决高并发问题
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档