- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我在两台不同的机器(例如A和B)上有相同的camel Rest api,最后这两台不同的机器(A和B)指向一个公共(public)应用程序服务器(例如C),其中执行记录更新,在执行更新之前有多种get方法来收集信息来自公共(public)应用程序服务器 (C)。 (这是 A 和 B 的通用 ID,例如 10)
我面临的情况是,我必须同步来自 A 和 B 的请求,或者一次只能处理 1 个请求,一旦完成,另一个请求就应该开始。
以下是我尝试过的:
机器A和B有共同的数据库,所以我尝试将请求A的ID存储在数据库中,并检查是否存在相同的ID,在B的情况下它应该等待。一旦A完成,它的处理ID就会从数据库和B中删除此时将检查它不会获取 ID,并将启动其进程。
不幸的是,我尝试过的解决方案似乎并不符合标准,如果您能提出一些解决方案,那就太好了。
PS:我使用 Camel 路线,在执行更新之前执行多个获取请求所以我想在等待中发出1个请求,这是无法通过同步实现的,因为机器A和B是不同的。
目前没有这样的代码可供粘贴
谢谢
最佳答案
您可以通过使用 JMS 队列将数据收集与更新操作解耦来“同步”此场景。 A 和 B 正在收集所需的数据,并最终将更新请求作为 JMS 消息生成到同一队列中。
C(或其他人)正在使用消息,并且仅针对 C 执行更新请求。
此异步解决方案意味着A 和 B 不需要对更新请求进行同步响应。
这从根本上改变了错误处理。您必须在消费者端处理更新错误。当 A 和 B 成功删除队列中的更新请求时,他们不再负责。如果稍后发生错误,则不会到达他们。因此,您需要验证 A 和 B 上的数据,如果数据不足以更新,则拒绝请求。
另一方面,当 C 宕机时,您可以处理 A 和 B 上的请求。只要代理可以删除消息,他们就不在乎。当C再次启动时,它可以处理排队的消息。
要在消费者端严格同步,您只需仅使用 1 个消费者。
如果您使用支持 message groups 的 JMS 代理(例如 ActiveMQ)您甚至可以调整此场景。假设您只需要同步具有相同 ID 的请求。在本例中,您将 ID 设置为 JMSXGroupID
。然后,您可以使用任意数量的消费者,并且代理会负责同一 ID 的所有请求都由同一消费者处理(因此是同步的)。
关于java - 如何将多台机器的PATCH http请求同步到单台机器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58539277/
我正在尝试使用 Android SDK 中的 Draw9Patch 工具,但在使用 Draw9Patch 打开我的图像后,它立即将我的所有图像区域显示为“坏补丁”。我手动绘制了定义可拉伸(stretc
我有一个运行补丁命令的构建工具,如果补丁命令返回非零值,它将导致构建失败。我正在应用一个可能已经或可能尚未应用的补丁,所以我使用 -N选项 patch ,它应该跳过。但是,当它确实跳过时,patch返
patching file chrome/browser/gpu_process_host_ui_shim.cc Unreversed patch detected! Skipping patch.
尝试查看哪些模型最适合api(更新少,但对象结构可能经常更改,高读取应用程序) 我有这样的资源 Epic(ID、名称、描述、开始日期、结束日期、状态、故事) 故事(ID、名称、说明、开始日期、结束日期
我创建了新问题,因为我觉得上一个问题已经得到解答,这属于一个新的地方。 我跑 bitbake core-image-minimal我收到以下错误: ERROR: systemd-1_232-r0 do
我正在使用 ColdFusion 10 与 PayPal 的服务器和 for some requests 进行通信我需要执行 HTTP PATCH 请求 are not supported by CF
我试图了解这两种模拟方法之间的区别。有人可以帮助区分它们吗?对于这个例子,我使用 passlib 库。 from passlib.context import CryptContext from un
WebTarget webTarget = httpClient.target(url); Invocation.Builder invocationBuilder = webTarget.reque
当提到“提交补丁”时,补丁这个词究竟是什么意思? 我已经看到它被大量使用,尤其是在开源世界中。它是什么意思,提交补丁到底涉及什么? 最佳答案 这是一个文件,其中列出了已更改的代码文件之间的差异。它通常
对于 matplotlib.patches,patch.contains_point(xy) 方法似乎与 patch.get_path().contains_point(xy) 不同,至少在拥有之后将
这是什么RFC 5789说: The PATCH method requests that a set of changes described in the request entity be ap
在 Draw 9-patch 中,一切看起来都很好。 但是,我的 SDK 说 9-patch png 格式不正确。因为我有类似 11-patch png 的东西。因为我不希望小抓取区域被缩放。如何让它
我创建了一个使用 javax.xml.ws.Endpoint 来创建 REST 端点的类: @WebServiceProvider @ServiceMode(value = javax.xml.ws.
语境 我有一个 spring boot (version 2.2.6.RELEASE) web 项目。 从这个 Web 应用程序(我称之为“APP1”)我想使用来自另一个 Web 应用程序的 PATC
在为我的应用程序编写单元测试时,我一直使用 @mock.patch 和 @patch.object 装饰器。但是现在,当我使用装饰器进行一些单元测试时,我收到错误消息“TypeError: stati
我在使用@mock.patch.object 函数时观察到 nosetests 的一个非常奇怪的行为: 当我同时运行多个测试时,我得到的结果与单独运行它们时不同。具体来说,在某些情况下,当我一起运行多
我正在使用 RestSharp v107。 我想更新测试用例的迭代路径。我可以使用 Postman 更新它,但使用 RestSharp 我收到“BAD Request”-“您必须在请求正文中传递有效的
我已经阅读了 GNU 项目中关于开源和其他许可证的文章。某些许可证允许您将更改发布为补丁,而不是完整的源代码(例如 Q 公共(public)许可证或 gnuplot 许可证)。这是什么意思?这样的补丁
有谁知道免费的优质补丁程序?您知道,可以将其中包含旧程序的目录放入其中,然后将其与具有新版本的目录进行比较,然后吐出一个补丁,这仅仅是两者之间的区别? 另外,我正在寻找可以修补整个目录的东西,而不仅仅
由于我当时一直在使用 Subversion 和 shell 工具,git-gui这些都是不可能的。是否有任何 shell 工具可以交互式地逐行应用补丁? 最佳答案 尝试通过 --dry-run选项 p
我是一名优秀的程序员,十分优秀!