我有应用程序代码,它在本地数据库中插入记录,在远程数据库中插入记录(通过Oracle Database Link)。当我提交这个分布式事务时,保证本地和远程数据库都提交或同时回滚,或者远程数据库是否有可能提交,但本地提交会失败(反之亦然)?
答案 0 :(得分:6)
如果Oracle不使用等效的Two-Phase Commit(2PC)协议,我会感到很惊讶,这可以确保提交或同时回滚。
使用2PC,有一个称为预提交阶段的阶段,其中主(协调者)实例记录自己的决定并告诉所有参与者准备好提交(并报告其状态 - 必须失败,或者可以提交)。参与者也准备好提交,并且(如果他们可以提交)在告知协调员他们准备提交之后等待协调员的进一步指示。当所有参与者都做出回应时,协调员记录最终决定,并将该决定发送给参与者,并根据其决定采取行动。如果主服务器在记录决策之后但在成功将决策发送给参与者之前失败,则参与者可以挂起,他们既不能提交也不能回滚。有办法从中恢复。如果协调员长时间停留(例如,由于灾难性的h / w故障而停止服务),你可能会遇到问题;参与者通常最终会进行启发式回滚(假定回滚) - 但这需要非常糟糕的运气才能造成任何麻烦。
有2PC的替代品;最终结果是相同的 - 所有提交或全部回滚。