Le pattern Transactional Outbox est présenté comme une solution élégante pour synchroniser une base de données PostgreSQL et un message broker comme RabbitMQ, évitant les problèmes des transactions distribuées (2PC). Contrairement à l'approche classique qui risque de publier un message sans que la transaction SQL ne soit validée, ce pattern repose sur l'écriture d'un événement dans une table dédiée au sein de la base de données, garantissant ainsi l'atomicité. Un job asynchrone se charge ensuite de publier le message dans RabbitMQ une fois la transaction principale réussie.
L'auteur souligne les limites des transactions distribuées (2PC), notamment l'absence de support XA pour RabbitMQ, les pénalités de performance et la dégradation de la disponibilité globale du système. Le pattern Transactional Outbox contourne ces problèmes en centralisant la fiabilité sur la base de données, simplifiant ainsi l'architecture tout en maintenant la cohérence des données.
La mise en œuvre pratique implique une transaction unique pour sauvegarder l'entité et l'événement dans la base, suivie d'un processus asynchrone pour publier le message. L'utilisation d'un verrou distribué (SchedulerLock) permet d'éviter les doublons dans un environnement multi-instances, offrant une solution robuste et performante pour les systèmes distribués.