我目前正在对Spring Boot / Axon应用程序进行集成测试。
在这些测试之一中,它(一个节点)通过SpringApplicationBuilder(在不同的配置文件下)创建另一个节点,并与其创建者连接到相同的Axon Server实例。
我遇到的问题是事件处理开始变得怪异,我相信带有第二个创建的节点的原始应用程序上的任何“常见”事件处理程序都会被忽略/丢失。 在测试环境之外启动实例时,一切似乎都正常运行。
我的想法是,在测试中,两个节点最终在Axon Server上共享一个实例名称(因为它们共享processId和主机名),这与处理程序的注册/跟踪相混淆。这有道理吗?
有没有一种方法可以为连接到Axon Server的节点手动设置此值,从而在测试期间不会发生这种情况?
答案 0 :(得分:2)
我不确定哪些组件由外部测试应用程序启动,哪些由内部测试应用程序启动。请注意,这里可能会影响您的多个方面。
axon.axonserver.clientId
属性定义其他clientId。只需将其设置为随机值,即可解决问题的这一部分。另一个问题是您的组件可能具有相同名称的跟踪处理器。在这种情况下,AxonServer会将处理器的两个实例视为同一处理器的多个实例,并平衡两者之间的负载(如果存在足够的段)。如果只有一个处理段可用,则只有一个处理程序将处于活动状态。另一个组件将不接收任何事件。
要避免这种情况,请在测试用例中为处理器的名称添加唯一的前缀。您可以使用EventProcessingConfigurer
的{{1}}方法来更改将组分配给处理器的规则。默认情况下,处理器的名称与组的名称相同。对于您的情况,可以(基于您设置的测试配置文件)在处理器名称中添加唯一的与测试相关的前缀。这将“欺骗” Axon相信它们是不同的处理器,并且需要同时运行。
我建议先尝试选项1。如果这还不足以进行测试,您也可以尝试第二个。