V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
zxc1234
V2EX  ›  程序员

关于 spring 事务数据源的问题请教

  •  
  •   zxc1234 · 2020-04-29 00:15:17 +08:00 · 1579 次点击
    这是一个创建于 1672 天前的主题,其中的信息可能已经有所发展或是发生改变。

    1.spring 同一个事务可以操作多个数据源吗? 2.如果不可以,为什么不可以呢? 3.spring 这样子设计的目的是什么呢? 谢谢~

    5 条回复    2020-04-29 09:20:21 +08:00
    zerozerone
        1
    zerozerone  
       2020-04-29 00:30:59 +08:00
    spring 并不提供具体的事务实现,只提供了事务的抽象实现,具体交给事务管理器进行提交和回滚,而事务管理器开启事务是在数据源上开启的。所以问题一的答案就很明显了。而要想实现操作多数据源时有事务保证,可以尝试写切面使用编程方式分别开启多个数据源的事务,最后再统一提交
    zerozerone
        2
    zerozerone  
       2020-04-29 00:35:03 +08:00
    当然也可以使用 JTA 进行多数据源的事务保证,或者其他的分布式事务解决方案
    skypyb
        3
    skypyb  
       2020-04-29 06:15:45 +08:00
    单机应用操作多个数据源要保证事务的话你只能 2PC 了。
    Ariver
        4
    Ariver  
       2020-04-29 08:52:23 +08:00 via iPhone
    shuqin2333
        5
    shuqin2333  
       2020-04-29 09:20:21 +08:00
    多个数据源不就类似于分布式事务了吗
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   5304 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 39ms · UTC 08:00 · PVG 16:00 · LAX 00:00 · JFK 03:00
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.