摘要: 1. 问题背景 上周线上某模块出现锁等待超时,如下图所示: 我虽然不是该模块负责人,但出于好奇,也一起帮忙排查定位问题。 这里的业务背景就是在执行到某个地方时,需要去表中插入一批数据,这批数据需要根据数据类型分配流水号。这与我的 "select for update引发死锁分析" 提到的流水号分配差 阅读全文
posted @ 2018-04-14 14:39 活在夢裡 阅读(3095) 评论(3) 推荐(1) 编辑
摘要: 线上发现执行某特定任务在某个特定时间点后不再work。该任务由线程池中线程执行定时周期性调度,根据日志查看无任何异常。从代码研判应该无关定时任务框架,因为对提交的定时任务做了wrap,会将异常都catch住,保证下次仍然能够正常调度。 通过jstack导出堆栈信息,发现问题线程的堆栈信息如下: 研判 阅读全文
posted @ 2018-03-20 20:56 活在夢裡 阅读(3581) 评论(1) 推荐(0) 编辑
摘要: 1. 简介 本文基于JDK8u111的源码分析WeakHashMap的一些主要方法的实现。 2. 数据结构 就数据结构来说WeakHashMap与HashMap原理差不多,都是拉链法来解决哈希冲突。 下面是WeakHashMap中的Entry结构定义。 另外,每个WeakHashMap内部都有一个R 阅读全文
posted @ 2018-02-11 20:45 活在夢裡 阅读(823) 评论(0) 推荐(0) 编辑
摘要: 1. 背景 本文基于MySQL InnoDB源码对InnoDB中非锁定一致性读是如何实现的作一些简单的探究。 2. 基本概念 2.1 隐藏字段 在经典之作《高性能MySQL》的1.4节中提及了MySQL中MVCC的实现,原著中提及了 InnoDB implements MVCC by storing 阅读全文
posted @ 2018-01-02 23:52 活在夢裡 阅读(2086) 评论(1) 推荐(0) 编辑
摘要: 本文针对MySQL InnoDB中在Repeatable Read的隔离级别下使用select for update可能引发的死锁问题进行分析。 1. 业务案例 业务中需要对各种类型的实体进行编号,例如对于x类实体的编号可能是x201712120001,x201712120002,x20171212 阅读全文
posted @ 2017-12-22 00:42 活在夢裡 阅读(44618) 评论(1) 推荐(9) 编辑
摘要: 1. 简介 JUC中的CyclicBarrier提供了一种多线程间的同步机制,可以让多个线程在barrier等待其它线程到达barrier。正如其名CyclicBarrier含义就是可以循环使用的屏障。 2. 源码解读 2.1 数据结构 2.1.1 Generation 在CyclicBarrier 阅读全文
posted @ 2017-12-02 17:44 活在夢裡 阅读(1157) 评论(1) 推荐(0) 编辑
摘要: 1.简介 ConcurrentLinkedQueue是JUC中的基于链表的无锁队列实现。本文将解读其源码实现。 2. 论文 ConcurrentLinkedQueue的实现是以Maged M. Michael和Michael L. Scott的论文 "Simple, Fast, and Practi 阅读全文
posted @ 2017-11-10 01:02 活在夢裡 阅读(1192) 评论(2) 推荐(0) 编辑
摘要: 简介 Treiber Stack在 R. Kent Treiber在1986年的论文 "Systems Programming: Coping with Parallelism" 中首次出现。它是一种无锁并发栈,其无锁的特性是基于CAS原子操作实现的。 实现 下面给出的Java语言实现为《Java并 阅读全文
posted @ 2017-10-23 22:12 活在夢裡 阅读(2135) 评论(0) 推荐(0) 编辑
摘要: 1. 背景 之前读JUC的AQS源码,读到Condition部分,我当时也写了一篇源码阅读文章 (AbstractQueuedSynchronizer源码解读 续篇之Condition)[http://www.cnblogs.com/micrari/p/7219751.html]。Doug Lea大 阅读全文
posted @ 2017-10-11 00:54 活在夢裡 阅读(3088) 评论(4) 推荐(3) 编辑
摘要: 1. 背景 在之前的博文 "ThreadPoolExecutor源码解读" 已经对ThreadPoolExecutor的实现原理与源码进行了分析。ScheduledExecutorService也是我们在开发中经常会用到的一种ExecutorService,JDK中它的默认实现类为Scheduled 阅读全文
posted @ 2017-10-10 00:28 活在夢裡 阅读(1208) 评论(0) 推荐(2) 编辑
摘要: 1. 背景 最近读了Spring声明式事务相关源码,现在将相关原理及本人注释过的实现源码整理到博客上并对一些工作中的案例与事务源码中的参数进行总结。 2. 基本概念 2.1 基本名词解释 | 名词 | 概念 | | |: | |PlatformTransactionManager|事务管理器,管理事 阅读全文
posted @ 2017-10-03 21:58 活在夢裡 阅读(9850) 评论(2) 推荐(13) 编辑
摘要: 1. 背景 在前文 "Spring IOC容器创建bean过程浅析" 已经介绍了Spring IOC创建初始化bean的大致过程。现在对Spring的AOP实现机制进行研究分析。 2. 名词与概念 | 名词 | 概念 | | |: | | Advice | 通知,在连接点的处理逻辑 | | Advi 阅读全文
posted @ 2017-09-24 00:46 活在夢裡 阅读(2145) 评论(0) 推荐(1) 编辑
摘要: 1. 背景 cglib库的Enhancer在Spring AOP中作为一种生成代理的方式被广泛使用。本文针对Enhancer的用法以实际代码为例作一些介绍。 2. Enhancer是啥 Enhancer是cglib中使用频率很高的一个类,它是一个字节码增强器,可以用来为无接口的类创建代理。它的功能与 阅读全文
posted @ 2017-09-20 23:22 活在夢裡 阅读(15017) 评论(0) 推荐(4) 编辑
摘要: 1. 背景 Spring框架本身非常庞大,源码阅读可以从Spring IOC容器的实现开始一点点了解。然而即便是IOC容器,代码仍然是非常多,短时间内全部精读完并不现实 本文分析比较浅,而完整的IOC创建bean实际上是非常复杂的。本文对于BeanDefinition的加载解析,bean实例化的反射 阅读全文
posted @ 2017-09-16 00:04 活在夢裡 阅读(5897) 评论(0) 推荐(2) 编辑
摘要: 背景 最近在项目中看到太多后台task中使用Executor框架,提交任务后,把future都一个个加入到list,再一个个get这些future的代码。 这个的问题在于一方面没有时限,可能会被某些运行缓慢的future拖很久。即便使用带超时控制的get方法,这样加入list再get的做法依然很繁琐 阅读全文
posted @ 2017-09-08 18:31 活在夢裡 阅读(530) 评论(0) 推荐(0) 编辑