Axonframework, ako používať MessageDispatchInterceptor s reaktívnou úloţiska

0

Otázka

Prečítal som si set-založené súlad overenie blogu a chcem overiť prostredníctvom odoslanie interceptor. Som nasledovať príklad, ale som pouţitie reaktívnych úloţiska a to nie je naozaj pre mňa pracovať. Snažil som sa obaja blok a nie bloku. s blokom to hodí chyba, ale bez blok nemusí vykonať nič. tu je môj kód.

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

Najlepšiu odpoveď

3

Upísali reaktívne úložiska v správe dispečer, v skutočnosti nie je odporúčané a môže viesť k divné správanie ako underling ThreadLocal (používané Axox) nie je prispôsobený byť použité v reaktívne programovania

Namiesto toho, pozrite sa Axon je Reaktívny, Rozšírenie a reaktívne interceptor časti.

Napríklad, čo by ste mohli robiť:

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

vďaka za radu, btw nechcem vidieť žiadne ReactorCommandBus rozšírenie by som mal použiť ReactroCommandGateway miesto?
Patrick

áno, sú tam iba reaktívne brány podporované
schananas

V iných jazykoch

Táto stránka je v iných jazykoch

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