连接到Axon Server时更改节点的实例名称

时间:2019-02-08 07:29:57

标签: java spring-boot kotlin axon

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

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

我遇到的问题是事件处理开始变得怪异,我相信带有第二个创建的节点的原始应用程序上的任何“常见”事件处理程序都会被忽略/丢失。 在测试环境之外启动实例时,一切似乎都正常运行。

我的想法是,在测试中,两个节点最终在Axon Server上共享一个实例名称(因为它们共享processId和主机名),这与处理程序的注册/跟踪相混淆。这有道理吗?

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

1 个答案:

答案 0 :(得分:2)

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

  1. AxonServer可能会感到困惑,并认为这两个组件实际上是相同的。确实,两者的主机名和processId相同,这使AxonServer认为它只是在处理来自同一应用程序的多个连接。为了避免这种情况,您可以使用axon.axonserver.clientId属性定义其他clientId。只需将其设置为随机值,即可解决问题的这一部分。
  2. 另一个问题是您的组件可能具有相同名称的跟踪处理器。在这种情况下,AxonServer会将处理器的两个实例视为同一处理器的多个实例,并平衡两者之间的负载(如果存在足够的段)。如果只有一个处理段可用,则只有一个处理程序将处于活动状态。另一个组件将不接收任何事件。

    要避免这种情况,请在测试用例中为处理器的名称添加唯一的前缀。您可以使用EventProcessingConfigurer的{​​{1}}方法来更改将组分配给处理器的规则。默认情况下,处理器的名称与组的名称相同。对于您的情况,可以(基于您设置的测试配置文件)在处理器名称中添加唯一的与测试相关的前缀。这将“欺骗” Axon相信它们是不同的处理器,并且需要同时运行。

我建议先尝试选项1。如果这还不足以进行测试,您也可以尝试第二个。