gpt4 book ai didi

java - 何时使用 XA 数据源和非 XA 数据源

转载 作者:行者123 更新时间:2023-12-02 01:41:53 26 4
gpt4 key购买 nike

我试图了解 Java XA 数据源的使用。但我仍然不知道何时使用它,何时不使用它。

我读到当我们使用两个数据库时使用 XA 数据源。但我不确定两个数据库是什么意思。

例如:

我有两层类(Service 和 DAO)

服务层的一个方法,注释为事务,调用DAO中的两个方法。

DAO 中的每个方法都会打开与数据库的新连接,并在方法结束时关闭它。

如果我使用一个数据库实例,并且 DAO 中的每个方法写入不同的表,我是否必须使用 XA 数据源?由于事务发生在服务层但仅在一个实例数据库中

最佳答案

诸如数据库之类的系统,以及通过 JMS 使用的排队系统等系统,都具有 transactions 的概念。 。事务被视为一个工作单元;在完成工作(例如在数据库中插入、更新或删除记录)后,您提交事务,然后数据库最终完成工作;或者您回滚事务,然后事务中完成的所有操作都被取消。

在某些情况下,您的软件必须在多个不同的系统上执行操作。例如,您可能需要将数据插入到多个数据库中,或者在数据库中插入某些内容并将消息放入队列中。

如果你想将这些操作组合起来,就像它们在一个事务中一样,那么你需要一个分布式事务系统——一个可以将不同系统的事务组合成一个的系统。这样您就可以编写代码,就好像它在单个事务中运行一样;分布式事务系统自动提交或回滚底层系统中的事务。

更具体地说:假设您在数据库中插入一条记录,并将一条消息放入队列中,并且您希望在一个事务中执行此操作。当将消息放入队列时出现问题时,您还希望回滚数据库事务,这样数据库中就没有记录,但队列上没有相应的消息。您可以使用分布式事务系统,而不是手动跟踪数据库和队列系统的事务(包括处理所有可能的错误组合)。

XA 是处理分布式事务的标准。您可以通过 Java Transaction API (JTA) 在 Java 中使用 XA 事务。 Java EE 服务器支持此内置功能。如果您不使用 Java EE 服务器,则可以使用实现 JTA 的单独库,例如 NarayanaAtomikos .

Each method in DAO open new connection to database and close it in the end of the method.

通常这不是您应该如何编写 DAO 的方式。打开数据库连接是一个相对较慢的操作;如果您为 DAO 中调用的每个方法打开一个新的数据库连接,您的程序很可能会运行缓慢。您至少应该使用一个连接池,它管理多个数据库连接并允许您重用已经打开的连接。

If I use one instance of database, and each method in DAO write to different table, do I have to use XA Datasource? since transaction occured in service layer but only in one instance database

如果您的 DAO 方法各自打开自己的连接,那么它们将在单独的事务中运行。这是否是一个问题取决于您的应用程序需要做什么。 XA 数据源并不是让它们在一个事务中运行的解决方案。相反,您应该让它们使用相同的连接和事务。

XA 事务实际上仅在您使用多个数据库系统或其他系统并且希望能够跨这些系统执行事务时才有用。

关于java - 何时使用 XA 数据源和非 XA 数据源,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54365485/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com