一文讲解Spring中事务的传播机制

什么是Spring中的是事务传播机制呢?

  • 事务的传播机制定义了方法在被另一个事务方法调用时的事务行为,这些行为定义了事务的边界和事务上下文如何在方法调用链中传播。
    在这里插入图片描述

  • Spring 的默认传播行为是 PROPAGATION_REQUIRED,即如果当前存在事务,则加入该事务;如果当前没有事务,则创建一个新的事务。

  • 事务传播机制是使用ThreadLocal实现的,所以,如果调用的方法是在新线程中,事务传播会失效

    @Transactional
    public void parentMethod() {
        new Thread(() -> childMethod()).start();
    }
    
    public void childMethod() {
        // 这里的操作将不会在 parentMethod 的事务范围内执行
    }
    

    Spring 默认的事务传播行为是 PROPAFATION_REQUIRED,即如果多个 ServiceX#methodX() 都工作在事务环境下,且程序中存在这样的调用链 Service1#method1()->Service2#method2()->Service3#method3(),那么这 3 个服务类的 3 个方法都通过 Spring 的事务传播机制工作在同一个事务中。

protected和private加事务会生效吗?

  • 在 Spring 中,只有通过 Spring 容器的 AOP 代理调用的公开方法(public method)上的@Transactional注解才会生效

  • 如果在 protected、private 方法上使用@Transactional,这些事务注解将不会生效,原因:Spring 默认使用基于 JDK 的动态代理(当接口存在时)或基于 CGLIB 的代理(当只有类时)来实现事务。这两种代理机制都只能代理公开的方法。

### Spring Cloud 和 Spring Cloud Alibaba 的介绍 Spring Cloud 是一个基于 Spring Boot 实现的微服务架构开发工具集,它提供了一系列用于快速构建分布式系统的工具,包括配置管理、服务发现、断路器、路由网关等功能[^1]。通过这些工具的支持,开发者可以更加高效地构建和部署复杂的分布式应用程序。 而 Spring Cloud Alibaba 则是在 Spring Cloud 基础上的扩展版本,旨在更好地支持阿里巴巴生态中的技术栈以及国内用户的实际需求[^2]。其主要目标是对现有的 Spring Cloud 功能进行补充和完善,同时集成阿里云的服务和技术能力,从而提升在国内环境下的适用性和性能表现。 --- ### Spring Cloud 和 Spring Cloud Alibaba 的区别 #### 1. **功能范围** - Spring Cloud 提供了一套通用的标准解决方案来解决微服务开发过程中的常见问题,例如服务注册与发现、负载均衡、熔断机制等。 - Spring Cloud Alibaba 不仅继承了 Spring Cloud 的核心特性,还引入了许多针对中国市场的优化措施及特定组件(如 Nacos、Sentinel),使得整个框架更贴合本地化场景的需求[^3]。 #### 2. **技术支持方向** - Spring Cloud 更注重国际化标准协议兼容性,适用于全球范围内多种不同类型的云计算平台之上运行的应用程序开发工作。 - 而 Spring Cloud Alibaba 主要围绕着阿里巴巴集团内部所使用的中间件产品线展开设计,比如 Dubbo RPC 框架和服务治理中心 Nacos 等,因此对于熟悉或者依赖于阿里的技术和基础设施体系结构的企业来说具有更高的契合度。 #### 3. **具体实现差异** 下表展示了两者之间部分重要模块的具体对比情况: | 组件名称 | Spring Cloud 默认实现 | Spring Cloud Alibaba 替代方案 | |----------------|------------------------------------------|----------------------------------------| | 配置管理 | Spring Cloud Config | Nacos | | 服务注册与发现 | Eureka | Nacos 或 Zookeeper | | 断路器 | Hystrix (已停止维护) | Sentinel | | 分布式链路追踪 | Sleuth + Zipkin | SkyWalking | 以上表格清晰表明,在某些方面 Spring Cloud Alibaba 使用了自己的替代品以满足特殊业务场景的要求并提高效率。 #### 4. **社区活跃程度与发展前景** 尽管两个项目都拥有庞大的用户群体和支持团队,但由于后者诞生时间较晚加上背后有强大的商业力量推动,所以在短期内可能会看到更多关于它的更新迭代动作发生;不过长期来看二者都会持续演进完善各自的生态系统。 --- ### 示例代码展示 以下是分别使用 `Eureka` 和 `Nacos` 进行简单服务注册的一个例子比较: #### 使用 Eureka 注册服务中心 ```java @SpringBootApplication @EnableEurekaClient public class ServiceApplication { public static void main(String[] args) { SpringApplication.run(ServiceApplication.class, args); } } ``` #### 使用 Nacos 注册服务中心 ```java @SpringBootApplication @NacosDiscoveryProperties(serverAddr = "localhost:8848") public class ServiceApplicationWithNacos { public static void main(String[] args) { SpringApplication.run(ServiceApplicationWithNacos.class, args); } } ``` 上述两段代码片段直观体现了切换到新的注册方式只需要改变少量注解即可完成迁移操作。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值