Par François WEMAERE et

Florent FREMONT, LeadDevs MAIF

Démarrer

avec Spring Webflux

  • Impératif / Réactif
  • Qu'est ce que Webflux ?
  • Flux / mono
  • Backpressure
  • Opérateurs
  • Modèle event loop
  • Pools de threads
  • Use cases

Sommaire

La programmation réactive est un paradigme de programmation visant à appliquer des opérateurs sur une source de données.

 

Elle s'appuie sur le patron de conception Observateur. On résonne en terme de Streams.

Impératif / Réactif

La notion de Mono est assez proche de celle de Promise en Javascript.

Text

Webflux ?

Un framework web spring basé sur la stack réactive reactor qui implémente notamment la norme réactive Streams

C'est une stack qui vient combler des lacunes de WebMVC sans totalement la remplacer.

Mono : 0..1 éléments 

Ex: récupérer un objet "Véhicule" depuis un appel réseau Mono<Vehicule>.

On peut aussi faire Mono<List<Vehicule>> si l'API REST nous le permet

 

Flux: 0..N éléments

Ex: Faire de l'event sourcing pour l'exposer en REST

Ex: Interconnexion avec une fil de messages (Kafka,...)

Mono / flux

Est un système qui permet de réguler la transmission des éléments.


Car une approche non bloquante peut démultiplier des appels et provoquer des erreurs en cascade.

Concrètement cela permet :

  • prévenir les défaillances systémiques

  • contrôler le volume des éléments (delay, request, ....)

  • gérer un tampon (buffer, ...)

  • perdre les éléments en "trop" (cancel, ...)

Backpressure

- map, flatMap, filter, doOnNext
- Mono zip, zipWith
- Mono switchIfEmpty
- Mono onErrorResume
- Flux collectList

Opérateurs usuels

Modèle Event loop

Pools de thread

Webflux permet une gestion du threading via les classes "Scheduler" et "Worker".
- `Schedulers.immediate()` : évite de changer de thread (exécute maintenant^^)
- `Schedulers.single()` : réutilise un seul thread (pour les traitements à faibles latences)
- `Schedulers.parallel()` : définit N Worker (fonction des coeurs, pour les traitements rapides et non bloquants)
- `Schedulers.elastic() / Schedulers.boundedElastic()` : génère des threads à la demande (long traitement bloquant)
 

Démo

en java

https://github.com/ffremont/start-with-webflux

resilience4j

WebClient

Démarrer avec Webflux

By Florent Fremont

Démarrer avec Webflux

  • 84