首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    加锁还是不加锁,这是一个问题

    3.不要加锁? 平淡的日子就这么过着, 有一天线程世界来了一个年轻人,自称为小李, 他看着我们这么努力地奋斗着去争抢那把锁, 不由地嘲笑道: 你们真傻啊, 难道不知道不加锁也能做事吗?...这句话把我们镇住了, 我小心翼翼地问: 那你说说,不加锁怎么才能保证正确性呢? “就拿你们的那个Sequence类来说吧, 不就是并发的更新内存中的一个值吗, 可以这么分为三步来做: 1....小李说:“你们Java 不是有JNI(Java native interface)吗? 可以用C语言来实现, 然后在Java中封装一下不就得了?” ?...AtomicLong AtomicIntegerArray AtomicLongArray 这些工具类都很好用, 大家非常喜欢, 只是我们发现小李的这些工具类只支持简单的类型,对于一些复杂的数据结构,就不好使用...6.后记:Doug Lea 如果说要从Java 世界中找一个并发编程的大牛, 我想这个人非Doug Lea莫属, 从JDK 1.5开始, Java 引入了一个非常著名的线程并发库java.util.concurrent

    2.2K60

    Innodb加锁规则

    加锁顺序 普通select查询 获取表级锁: MDL读锁 不需要其他锁: 因为使用的是MVCC,所以不需要行锁 ps: 很多地方都说使用了MVCC就不需要加锁,实际上是不需要行锁,MDL读锁还是需要的...再获取表级锁: 意向排它锁 再获取行级锁: 插入意向锁 update/delete 首先获取表级锁: MDL写锁 再获取表级锁: 意向排它锁 再获取行级锁: 根据不同语句获取对应的行锁和间隙锁 行锁加锁规则...两个“原则”、两个“优化”和一个“bug” 原则 1:加锁的基本单位是 next-key lock。...原则 2:查找过程中访问到的对象才会加锁。 优化 1:索引上的等值查询,给唯一索引加锁的时候,next-key lock 退化为行锁。...MySQL加锁分析

    79910

    innodb加锁机制

    序 我们已知,RC、RR下: 快照读(普通select)会开启ReadView,使用mvcc机制防止脏读/不可重复读/幻读,不加锁。...另外: RU下,读取不加锁,修改加锁 RC下,查找索引不用到gap lock和next-key lock,只有record lock。所以当前读只会施加record lock。...SR下,没有mvcc机制,读、写都靠加锁来维持正确性。 我们最常用的还是RR等级,其加锁机制较为复杂,判断条件似乎很多,因此需要重点讨论。...另外,为了简化讨论,本文只讨论RR下select...for update的加锁机制。 1....这时,只需对该记录加锁,就能防止幻读。 加锁机制图解如下: ? 加锁机制 施加gap lock的范围 那么,Innodb会对多大的范围施加gap lock呢?

    1.1K20

    【转载】加锁还是不加锁,这是一个问题

    【转载】加锁还是不加锁,这是一个问题 2017-06-14 by Liuqingwen | Tags: 随笔 Java | Hits 非常浅显易懂又寓意深刻的一篇文章,转载自微信公众号...三、不要加锁? 平淡的日子就这么过着,有一天线程世界来了一个年轻人,自称为小李,他看着我们这么努力地奋斗着去争抢那把锁,不由地嘲笑道:你们真傻啊,难道不知道不加锁也能做事吗?...小李说:“你们 Java 不是有 JNI(Java native interface) 吗?可以用 C 语言来实现,然后在 Java 中封装一下不就得了?” ?...AtomicLong AtomicIntegerArray AtomicLongArray 这些工具类都很好用,大家非常喜欢,只是我们发现小李的这些工具类只支持简单的类型,对于一些复杂的数据结构,就不好使用...六、后记: Doug Lea 如果说要从 Java 世界中找一个并发编程的大牛,我想这个人非 Doug Lea 莫属,从 JDK 1.5 开始, Java 引入了一个非常著名的线程并发库 java.util.concurrent

    84750

    JAVA并发之加锁导致的活跃性问题剖析

    首先提及一下前置知识: 1.JAVA并发之基础概念 2.JAVA并发之进程VS线程 3.JAVA并发之多线程引发的问题剖析及如何保证线程安全 在前三章我们讨论了多线程并发的优点以及如何加锁来处理并发带来的安全性问题...这个和简单的加锁超时类似,不一样的是只有死锁已经发生了才回退,而不会是因为加锁的请求超时了。...解决饥饿 Java 不可能实现 100% 的公平性,我们依然可以通过同步结构在线程间实现公平性的提高。...CAS 算法 - Java 的 Atomic 包使用 CAS 算法来更新数据,而不需要加锁。...总结 至本章为止,多线程并发的概念篇就结束了,实际操作篇尽情期待 持续关注公众号 JAVA宝典

    1.1K31

    【死磕Java并发】-----分析 ArrayBlockingQueue 构造函数加锁问题

    原文出处http://cmsblogs.com/ 『chenssy』 昨天有位小伙伴问我一个 ArrayBlockingQueue 中的一个构造函数为何需要加锁,其实这个问题我还真没有注意过。...主要是在看 ArrayBlockingQueue 源码时,觉得它很简单,不就是通过加锁的方式来操作一个数组 items 么,有什么难的,所以就没有关注这个问题,所以它一问我懵逼了。...如果不加锁为什么就没法保证 items 的可见性呢?这其实是指令重排序的问题。 什么是指令重排序?编译器或运行时环境为了优化程序性能而采取的对指令进行重新排序执行的一种手段。...更多请参考博客【死磕Java并发】—–Java内存模型之重排序。 为什么说指令重排序会影响 items 的可见性呢?...推荐阅读: 【死磕Java并发】—–Java内存模型之重排序 【死磕Java并发】—–Java内存模型之从JMM角度分析DCL 【死磕Java并发】—–深入分析volatile的实现原理 【死磕Java

    1.2K60

    Oracle给Select结果集加锁,Skip Locked(跳过加锁行获得可以加锁的结果集)

    1、通过select for update或select for update wait或select for update nowait给数据集加锁 具体实现参考select for update和select...for update wait和select for update nowait的区别 2、Skip Locked(跳过加锁行获得可以加锁的结果集) Skip locked是oracle 11g引入的...通过skip locked可以使select for update语句可以查询出(排除已经被其他会话加锁了的数据行)剩下的数据集,并给剩下的数据集,进行加锁操作。...a、测试一、 代码如下:新建一个SQL窗口1(相当于新建一个会话),执行 update test8 set price=6 where ID=1 但是不执行commit操作,此时,当前数据已经被加锁了。...此时,不进行commit操作,表中所有的数据行被加锁

    1.9K80

    JAVA并发之加锁导致的活跃性问题剖析

    在前三章我们讨论了多线程并发的优点以及如何加锁来处理并发带来的安全性问题 但是加锁也为我们带来了诸多问题 如:死锁,活锁,线程饥饿等问题 这一章我我们主要处理锁带来的问题....T2 time out T4 time out T3 time out 2.按顺序加锁 >按照顺序加锁是一种有效防止死锁的机制,但是这种方式,你需要先知道所有可能用到锁的位置,并对这些锁安排一个顺序...这个和简单的加锁超时类似,不一样的是只有死锁已经发生了才回退,而不会是因为加锁的请求超时了。...解决饥饿 Java 不可能实现 100% 的公平性,我们依然可以通过同步结构在线程间实现公平性的提高。...CAS 算法 - Java 的 Atomic 包使用 CAS 算法来更新数据,而不需要加锁

    48220

    InnoDB 事务加锁分析

    FOR UPDATE),InnoDB 通过加锁来实现可重复读,且InnoDB 加锁同时解决了幻读问题。...Gap Locks(间隙锁):在索引记录之间加锁,或者在第一个索引记录之前加锁,或者在最后一个索引记录之后加锁。 Next-Key Locks:在索引记录上加锁,并且在索引记录之前的间隙加锁。...四、案例分析 在对SQL进行加锁分析前,需要明确表的结构和索引类型。在不知道索引的情况下直接给出一条SQL来分析如果加锁是没有任何意义的。...MySQL InnoDB的可重复读并不保证避免幻读,需要应用使用加锁读来保证。而这个加锁读使用到的机制就是next-key locks。...可以这么讲,InnoDB提供了这样的机制,在默认的可重复读的隔离级别里,可以使用加锁读去查询最新的数据。

    1.7K00

    MySQL 加锁处理分析

    先对一条满足条件的记录加锁,返回给MySQL Server,做一些DML操作;然后在读取下一条加锁,直至读取完毕。...从上图可以看出,2PL就是将加锁/解锁分为两个完全不相交的阶段。加锁阶段:只加锁,不放锁。解锁阶段:只放锁,不加锁。...为什么聚簇索引上的记录也要加锁?...深入理解MySQL如何加锁,有两个比较重要的作用: 可以根据MySQL的加锁规则,写出不会发生死锁的SQL; 可以根据MySQL的加锁规则,定位出线上产生死锁的原因; 下面,来看看两个死锁的例子 (一个是两个...而使用本文上面提到的,分析MySQL每条SQL语句的加锁规则,分析出每条语句的加锁顺序,然后检查多个并发SQL间是否存在以相反的顺序加锁的情况,就可以分析出各种潜在的死锁情况,也可以分析出线上死锁发生的原因

    3.5K61

    insert 语句加锁机制

    一 前言 之前的文章里面总结了很多死锁案例,其实里面有几篇文章对于insert加锁流程表述的不准确,而且微信公众号又无法修改,所以通过本文重新梳理insert加锁流程,最后加上一个死锁案例解析...T_T 二 基础知识 在分析死锁案例之前,我们先学习一下背景知识 insert 语句的加锁策略,来看看官方定义: "INSERT sets an exclusive lock on the inserted...然而,文档没有说明的是,对于检测到冲突的唯一索引,等待线程在获得S Lock之后,还需要对下一个记录进行加锁,在源码中由函数row_ins_scan_sec_index_for_duplicate进行判断...| c2 | +----+----+----+ | 27 | 3 | 4 | | 30 | 5 | 8 | +----+----+----+ 无锁阻塞 单纯的insert,无其他事务对相关记录加锁...通过这样的逻辑来测试insert 语句遇到唯一键的时候的加锁流程。

    3.1K30

    MySQL加锁实战分析

    加锁的基本单位是next-key lock(前开后闭区间) 查找过程中访问到的对象才会加锁 索引上的等值查询,给唯一索引加锁的时候,next-key lock退化为行锁 索引上的等值查询,向右遍历时且最后一个值不满足等值条件的时候...,next-key lock退化为间隙锁 加锁的基本单位虽然是next-key lock,但是在具体执行的时候,是要分成间隙锁和行锁两段来执行的。...: 根据规则1,加锁单位是next-key lock,Session A的加锁范围是(5, 10] 根据规则4,SessionA是等值查询,而id=10不满足等值条件,因此next-key lock退化为间隙锁...next-key lock,因此加锁范围是(0, 5] 索引c是普通索引,根据规则4,最终会退化成间隙锁(5, 10) 根据规则2,只有访问到的对象才会加锁,由于Session A的查询使用覆盖索引,并不需要访问主键索引...因此在删除数据的时候我们如果加上limit,不仅可以控制删除的条数,还可以减小加锁的范围。

    1.1K30
    领券