- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个 Azure api 应用程序 (AzureApi1),它有一个发出多个 http 请求的操作。该操作将多个表的数据插入到 Azure Sql Db。
然后,它从同一代码中进行外部 API 调用 (ExApi)。使用外部调用的结果插入/更新一些其他表。这不在 Azure 中。
然后,它调用另一个 api (AzureApi2),该 API 与第一个 API 位于同一资源组中,并将数据插入到也位于同一资源组中的另一个 Azure Sql Db。
我在 AzureApi1 和 AzureApi2 中都使用了 TransactionScope,这对它们单独工作得很好。但是,由于中间有一个外部 api,并且该 api 不在我的控制范围内,因此如果该 api 调用发生任何故障,我需要回滚整个操作。目前,第一个 api 正在正确回滚,但是,由于第二个 api 调用是不同的 http 调用,因此它不属于第一个 api 的事务范围。如果发生任何失败,我还需要一种方法来回滚第二个 Sql Db 中的数据。
在这种情况下手动回滚的最佳选择是什么?
最佳答案
对于多个 Azure SQL DB 之间的分布式事务,您可以使用 elastic database transactions 。但弹性数据库事务无法跨本地 SQL Server 和 Azure SQL 数据库延伸。您需要针对这种情况创建自己的分布式事务协调器。
我建议您创建一个新的 Web API,它作为协调器来监视所有操作的状态。步骤可能如下所示,
如果操作失败,它应该向协调器发送一条消息(成功或失败)。
如果所有操作都完成,协调器将向所有操作发送消息(提交或回滚)。该消息取决于从每个操作接收到的所有消息。
每个操作都会提交更改并将提交结果(成功或失败)发送给协调器。
协调器将根据每个操作收到的提交结果向每个操作发送最终状态。
我们可以为这些通信添加超时。如果发生超时,我们需要回滚所有操作。
关于c# - 在 Azure 分布式事务中,如果一个 http 调用失败,回滚完整操作的最佳方法是什么,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43723178/
我打算使用 vulkan synchronization examples 之一作为如何处理不经常更新的统一缓冲区的引用。具体来说,我正在看这个: vkBeginCommandBuffer(...);
我对 git 的了解有限。 我已经从 master 创建了一个分支 B1,进行了一些编辑并提交到这个分支。 我想从 B1 创建另一个分支 B2,我在 B2 中进行了一些编辑 而且我还想提交 B2(包含
这是我做的 我创建了一个分支 abc。然后我创建了两个文本文件 one.txt 和 two.txt。然后我将它们提交到分支 abc。然后我从分支中删除文件 one.txt 并将这些更改提交到分支。 现
在我的主分支中,我得到了 2 个文件: file1.txt file2.txt 我从那里创建了名为 b1 的新分支。在b1中,我修改了file2.txt,不小心删除了file1.txt(从磁盘中,当我
我是 git 的新手。 我创建了一个分支,进行了更改,现在我想 merge 回 master 以使它们“永久化”。 所以我执行了 git merge 1.2 报告为已经是最新的,在 master 上执
我在一个新团队中,工作方式与我以前习惯的完全不同,我们在功能分支上工作,测试人员会在该功能分支上进行测试,然后我们会运行一个 jenkins 作业在该功能被测试签署时将该功能 merge 到开发中,根
我目前正在学习动态内存管理是如何工作的,更具体地说是 realloc 以及它是如何在函数中完成的。 在下面的程序中,我只是想尝试使用 malloc 在函数 a() 中分配一些数字,然后将它们传递给另一
在 Java 中如何从另一个线程分派(dispatch)回主 UI 线程?我正在使用带有 Runnable 的执行器在主 UI 线程之外做一些工作,并且我有一个接口(interface),以便可以通过
我在 git 中有一个项目,所有的事情都直接在 master 分支上完成,标签被用来标记代码的发布版本。我知道这并不理想,并且一直在查看 git 流程,例如:http://nvie.com/posts
我们有一个相当大的 GIT 存储库,我想删除从未 merge 回 master 的分支。 反过来也很好 - 一种列出在某个时候已 merge 到 master 中的所有分支的方法。 我希望首先获取一个
在 Swift 和 C 之间传递字符串时,我看到一些我不理解的行为。请考虑以下 Swift 函数: func demo() { print("\n\n\n\n")
我以前从未合作过,现在我发现自己需要与其他一些人分享这个项目,即使我将完成 90% 的开发工作。 我在 github 上有一个私有(private)仓库。我用 推送了我的初始源 git push or
我们的项目使用 Gitlab,我们有两个长期存在的分支:dev 和 master,类似于 Git Flow。我们正在使用“merge 提交”方法,它将在主分支中创建一个 merge 提交。 但是,由于
我对自定义 View 的绑定(bind)属性有疑问。该属性绑定(bind)到核心数据实体的 NSArrayController。 问题是这样的: 在我看来,我画了几个矩形。这些矩形的位置保存在核心数据
这对我来说似乎太棘手,无法正确执行此操作。 我有一个TreeMap ,我正在获取其中的子图: public static reqObj assignObj(reqObj vArg, i
我有以下 XAML: 所以,基本上我希望将其中一
我正在使用 Angular js 1.3.4 版本并使用 ui-select。 我正在将复杂的多级 JSON 对象数组绑定(bind)到此 ui-select,它工作正常。因此用户可以在此选择中选择任
我正在使用 WebAPI 构建 API,并且一直在使用 NLog 在整个堆栈中进行日志记录。我的 API 解决方案有两个主要项目,包括: 实现 Controller 和 webapi 东西的网站层本身
在 Git 中,给定 (1) 一个分支 A 和 (2) 一个在过去某个时间从 A 派生的分支 B,然后 merge 回 A,我如何才能找到现在 A 中起源于 B 的所有提交? 目的是确定现在在 A 中
假设我的 Controller 如下所示: public class myController { private MyCustomItem acte; ... // gett
我是一名优秀的程序员,十分优秀!