连接到 Axon 服务器时更改节点的实例名称

Change a node's Instance Name when connecting to Axon Server

我目前正在为 Spring Boot / Axon 应用程序进行集成测试。

在其中一个测试中,它(一个节点)通过 SpringApplicationBuilder(在不同的配置文件下)创建另一个节点,连接到与其创建者相同的 Axon 服务器实例。

我遇到的问题是事件处理开始表现得很奇怪,我相信带有第二个创建节点的原始应用程序上的任何 'common' 事件处理程序都会得到 ignored/lost。 当实例在测试环境之外启动时,一切似乎都正常。

我的想法是,在测试中,这两个节点最终在 Axon 服务器上共享一个实例名称(因为它们共享一个 processId 和主机名),这与处理程序 registration/tracking 混淆了。这有意义吗?

有没有一种方法可以让我为连接到 Axon 服务器的节点手动设置此值,以便在测试期间不会发生这种情况?

我不确定哪些组件由外部测试应用程序启动,哪些由内部测试应用程序启动。请注意,这里有多个方面可能会妨碍您。

  1. AxonServer 可能会混淆并认为这两个组件实际上是相同的。事实上,两者的主机名和 processId 将是相同的,这导致 AxonServer 认为它只是处理来自同一应用程序的多个连接。为避免这种情况,您可以使用 axon.axonserver.clientId 属性 定义不同的 clientId。只需将其设置为一个随机值,就可以解决这部分问题。

  2. 另一个问题是您的组件可能具有同名的跟踪处理器。在这种情况下,AxonServer 会将处理器的两个实例视为同一处理器的多个实例,并平衡两者之间的负载(如果存在足够的段)。如果只有一个处理段可用,则只有一个处理程序处于活动状态。其他组件将不会收到任何事件。

    为了避免这种情况,请在您的测试用例中为您的处理器名称加上一些独特的前缀。您可以使用 EventProcessingConfigurerassignProcessingGroup(Function<String, String> assignmentRule) 方法来更改将组分配给处理者的规则。默认情况下,处理器的名称与组的名称相同。在您的情况下,您可以(根据您设置的测试配置文件)向处理器名称添加一个唯一的与测试相关的前缀。这将使 'trick' Axon 相信它们是不同的处理器,并且需要同时 运行。

我建议先尝试选项 1。如果这还不够,你也可以试试第二个。