zoukankan      html  css  js  c++  java
  • 分布式事务02Springtx核心

    核心类及方法

    Spring-tx-4.3.14.RELEASE

    核心: 拦截器, 和其父类 org.springframework.aop.framework.ReflectiveMethodInvocation 相关(aop的包里) 以及 org.springframework.transaction.interceptor.TransactionAspectSupport 相关

    org.springframework.transaction.interceptor.TransactionInterceptor 类中的 invoke(final MethodInvocation invocation) 方法中的 invokeWithinTransaction() 方法

    开启事务, 执行sql, 提交或回滚的核心逻辑: invokeWithinTransaction(Method method, Class<?> targetClass, final InvocationCallback invocation)

    if (txAttr == null || !(tm instanceof CallbackPreferringPlatformTransactionManager)) {
    	// Standard transaction demarcation with getTransaction and commit/rollback calls.
        // 创建事务, 如果加了 @Transaction 注解, 就会创建
    	TransactionInfo txInfo = createTransactionIfNecessary(tm, txAttr, joinpointIdentification);
    	Object retVal = null;
    	try {
    	    // This is an around advice: Invoke the next interceptor in the chain.
    	    // This will normally result in a target object being invoked.
            // 执行sql, 就是自己写的语句
            retVal = invocation.proceedWithInvocation();
    	}
    	catch (Throwable ex) {
    	    // target invocation exception
            // catch异常执行回滚
    	    completeTransactionAfterThrowing(txInfo, ex);
    	    throw ex;
    	}
    	finally {
    	    cleanupTransactionInfo(txInfo);
    	}
        // 提交事务, 落库
    	commitTransactionAfterReturning(txInfo);
    	return retVal;
    }
    

    事务核心调用链

    结论: 通过一系列的调用, 先找到合适的 PlatformTransactionManager(事务管理器), 有jpa的包默认用jpa的事务管理器, 选用对应的连接池, 再执行对应的抽象父类的begin方法, 最终使用jdbc包下的api开启/提交/回滚事务

  • 相关阅读:
    VIM 第二天--快捷键
    Vim 第一天
    The Salt Master has cached the public key报错解决办法
    nginx启用TCP反向代理日志配置
    FastDFS数据迁移
    nginx修改上传文件大小限制
    ipv6禁用导致rpcbind服务启动失败解决办法
    ELK之elasticdump迁移es数据
    MySQL+Amoeba实现数据库读写分离
    使用Zabbix监控RabbitMQ消息队列
  • 原文地址:https://www.cnblogs.com/richardhaha/p/15780488.html
Copyright © 2011-2022 走看看