JGroups

Un article de Wikipédia, l'encyclopédie libre.
Aller à : navigation, rechercher

JGroups est un système fiable (c'est-à-dire qui ne perd pas les messages) de multicast écrit dans le langage Java.

Multicast[modifier | modifier le code]

Nous disposons de plusieurs moyens pour communiquer avec une ou un groupe de machines :

  • Unicast : Dans ce système, chaque message a un destinataire. Donc, pour envoyer le même message à plusieurs personnes, il faut le dupliquer pour chaque destinataire.
  • Multicast : Dans ce système, chaque machine qui désire recevoir les messages vers un groupe donné s'enregistre sur une adresse (l'adresse de groupe). Pour envoyer, il suffit donc d'envoyer à l'adresse du groupe, une et une seule fois.
  • Broadcast : Dans ce système, chaque message est envoyé à chaque machine qui se trouve sur le réseau. Donc, les machines doivent elles-mêmes filtrer les messages non-désirés.

TCP/IP propose un système de multicast et JGroups a été initialement créé pour pouvoir automatiser le processus d'abonnement, réception et désabonnement d'un multicast IP. Elle supportait donc les fonctionnalités suivantes:

  • Création et destruction de groupes multicast. Ces groupes peuvent être sur un réseau local ou un réseau de grande taille.
  • Abonnement et désabonnement de ces groupes.
  • Transmission de messages (non-fiables) entre groupe.

Extensions fournies par JGroups[modifier | modifier le code]

Le multicast IP est utilisé dans diverses applications:

  • Diffusion en temps réel de flux audio ou vidéo: dans ce cas, si un paquet est perdu ou arrive dans un mauvais ordre la perte n'est pas très importante, les paquets précédents et suivants sont probablement suffisants pour récupérer.
  • Le protocole OSPF, pour la détection automatique de routeurs: dans ce cas, la perte des paquets n'est pas un problème car très peu probable.

Ces applications ne nécessitant pas un contrôle de flux, le multicast IP utilise un protocole non-fiable et n'ayant aucun contrôle d'ordonnancement. JGroups a rapidement été étendu pour pouvoir pallier ces manques et offre plus de fonctionnalités et de flexibilité:

  • Un choix parmi des divers protocoles de transport: UDP, TCP ou encore JMS.
  • Détection d'abonnement et notifications au sujet des membres qui ont rejoint ou quitté le groupe.
  • Détection et enlèvement de membres s'étant "plantés" (terminaison inattendue).
  • Transmission fiable et ordonnée des messages.
  • Messages point-à-point.
  • Fragmentation des messages trop grands.
  • Politiques d'ordonnancement: atomique (tout ou rien), FIFO, ordre total.
  • Encryption.
  • etc.

JGroups est donc un système simple, rapide et fiable permettant de mettre en communication un ensemble de machines et proposer des services tels que la synchronisation, la répartition de charge ou encore la substitution (failover) en cas de problème.

Usages[modifier | modifier le code]

JGroups est utilisé dans de divers applications:

  • JBoss et JOnAS utilisent tous les deux JGroups pour gérer les parties distribués du serveur et la distributions des caches
  • GroupPac (une implémentation de la spécification CORBA tolérente aux fautes) utilise JGroups
  • Autodesk LocationLogic utilise JGroups dans son mechanisme de replication de cache
  • etc.

Ressources[modifier | modifier le code]