Spring中 @Transactional 注解的限制1. 同一个类中, 一个nan-transactional的方法去调用transactional的方法, 事务会失效 If you use (default) Spring Proxy AOP, then all AOP functionality provided by Spring (like @Transational) will only be taken into account if the call goes through…
1.MTR(mini-transaction) 在MySQL的 InnoDB日志管理机制中,有一个很重要的概念就是MTR.MTR是InnoDB存储擎中一个很重要的用来保证物理写的完整性和持久性的机制. 先看下MTR在MysQL架构中的位置. MTR是上面的逻辑层与下面物理层的交互窗口,同时也是用来保证下层物理数据正确性.完整性及持久性的机制. 2.日志刷盘的触发条件 触发条件 描述 时间 线程默认每秒刷新一次. 空间 Log Buffer空间用完了 Check Point checkPoint的…
mysql事务原理及MVCC 事务是数据库最为重要的机制之一,凡是使用过数据库的人,都了解数据库的事务机制,也对ACID四个 基本特性如数家珍.但是聊起事务或者ACID的底层实现原理,往往言之不详,不明所以.在MySQL中 的事务是由存储引擎实现的,而且支持事务的存储引擎不多,我们主要讲解InnoDB存储引擎中的事 务.所以,今天我们就一起来分析和探讨InnoDB的事务机制,希望能建立起对事务底层实现原理的具 体了解. 事务的特性 原子性:事务最小工作单元,事务开始要不全部成功,要不全部失败.…
SPI机制中的SPI实现类的读取和预处理是由ExtensionLoader类的loadFile方法来完成的 loadFile方法的作用是读取dubbo的某个SPI接口的spi描述文件,然后进行缓存,缓存,缓存(很重要,说三遍) ,读取的位置是在jar包下的META-INF\dubbo\internal目录下  一. 先对loadFile方法进行下粗的了解: loadFile方法方法被调用的顺序如下: getExtensionClasses() ——> loadExtensionClasses()…
1.java语言使用Thread类及其子类对象来表示线程,新建的一个线程声明周期中经历 新建.(声明一个线程,此时他已经有了相应的内存空间和其他资源),运行(线程创建之久就据用了运行的条件,一旦轮到使用CPU,此线程就会脱离创建他的主线程开始自己使命.此线程调用start()方法.通知JVM,这样JVM就会知道一个新的线程排队等候了.子类线程中必须重写Thread父类中的run方法,不然会发生异常.).线中断机制,就是此线程使用Thread中的方法 sleep(int millsecond)此时…
Linux内存管理机制中buffer和cache的区别理解linux内存管理,需要深入了解linux内存的各个参数含义和规则,下面介绍一下Linux操作系统中内存buffer和cache的区别. Freefree 命令相对于top 提供了更简洁的查看系统内存使用情况: [root@blliu ~]# free -mt             total       used       free     shared    buffers     cachedMem:          3886…
Java 反射机制中 getMethod()和getDeclaredField()区别 今天在程序中用到java反射机制时,遇到的问题记录一下:我当时遇到的问题是,我用反射getMethod()调用类方法时,发生NoSuchMethodException异常,后来上网发现getMethod()调用公共方法,不能反射调用私有方法,后来找到getDeclaredField()能够访问本类中定义的所有方法.后来用这个方法解决了我遇到的问题.我查了java api文档,其中详细说明如下: Method…
AtomicStampedReference AtomicReference解决CAS机制中ABA问题 AtomicStampedReference AtomicStampedReference它内部不仅维护了对象值,还维护了一个版本号(可以是任何一个整数,它使用整数来表示状态值).当AtomicStampedReference对应的数值被修改时,除了更新数据本身外,还必须要更新版本号.因此只要版本号发生变化,就能防止不恰当的写入.版本号类似于时间戳. import java.util.conc…
PostgreSQL的并发控制机制同时实现了多版本控制MVCC协议和两阶段封锁协议.实际采用哪种协议取决于所执行的语句类型. DML语句的并发控制将使用MVCC协议: DDL语句的并发控制基于标准的两阶段封锁协议. MVCC的关键思想是维护每一行的不同版本,而不同版本对应着在不同的时间点该行的不同实例.MVCC协议确保每个事务都只看到与事务的数据库视图一致的版本的数据:每个事务看到数据的一个快照,只包含那些在事务启动时已提交的数据.这个快照并不等于数据的当前状态. 使用MVCC的目的 是让读操作…
提到事务,你肯定会想到ACID(Atomicity.Consistency.Isolation.Durability,即原子性.一致性.隔离性.持久性),我们就来说说其中I,也就是"隔离性". 当数据库上有多个事务同时执行的时候,就可能出现脏读(dirty read).不可重复读(non-repeatable read).幻读(phantom read)的问题,所以下面我们来说说隔离级别. SQL标准的事务隔离级别包括:读未提交(read uncommitted).读提交(read c…