Axonframework, как использовать MessageDispatchInterceptor с реактивным репозиторием

0

Вопрос

Я прочитал блог проверки согласованности на основе наборов и хочу проверить его с помощью перехватчика отправки. Я следую примеру, но я использую реактивный репозиторий, и это действительно не работает для меня. Я пробовал как блокировать, так и не блокировать. с блоком он выдает ошибку, но без блока он ничего не выполняет. вот мой код.

class SubnetCommandInterceptor : MessageDispatchInterceptor<CommandMessage<*>> {

  @Autowired
  private lateinit var privateNetworkRepository: PrivateNetworkRepository

  override fun handle(messages: List<CommandMessage<*>?>): BiFunction<Int, CommandMessage<*>, CommandMessage<*>> {
    return BiFunction<Int, CommandMessage<*>, CommandMessage<*>> { index: Int?, command: CommandMessage<*> ->
      if (CreateSubnetCommand::class.simpleName == (command.payloadType.simpleName)){
        val interceptCommand = command.payload as CreateSubnetCommand
        privateNetworkRepository
          .findById(interceptCommand.privateNetworkId)
          // ..some validation logic here ex.
          // .filter { network -> network.isSubnetOverlap() }
          .switchIfEmpty(Mono.error(IllegalArgumentException("Requested subnet is overlap with the previous subnet.")))
          // .block() also doesn't work here it throws error
         // block()/blockFirst()/blockLast() are blocking, which is not supported in thread reactor-
      }
      command
    }
  }
}
axon axon-framework kotlin
2021-11-24 06:18:54
1

Лучший ответ

3

Подписка на реактивный репозиторий внутри диспетчера сообщений на самом деле не рекомендуется и может привести к странному поведению, поскольку подчиненный ThreadLocal (используемый Axox) не приспособлен для использования в реактивном программировании

Вместо этого ознакомьтесь с разделом реактивного расширения и реактивных перехватчиков Axon.

Например, что вы могли бы сделать:

reactiveCommandGateway.registerDispatchInterceptor(
        cmdMono -> cmdMono.flatMap(cmd->privateNetworkRepository
      .findById(cmd.privateNetworkId))
.switchIfEmpty(
Mono.error(IllegalArgumentException("Requested subnet is overlap with the previous subnet."))
.then(cmdMono)));
2021-11-24 13:26:24

спасибо за совет, кстати, я не вижу никакой шины Reactorcommand в расширении, должен ли я вместо этого использовать ReactroCommandGateway?
Patrick

да, поддерживаются только реактивные шлюзы
schananas

На других языках

Эта страница на других языках

Italiano
..................................................................................................................
Polski
..................................................................................................................
Română
..................................................................................................................
한국어
..................................................................................................................
हिन्दी
..................................................................................................................
Français
..................................................................................................................
Türk
..................................................................................................................
Česk
..................................................................................................................
Português
..................................................................................................................
ไทย
..................................................................................................................
中文
..................................................................................................................
Español
..................................................................................................................
Slovenský
..................................................................................................................