Conception de serveurs d'applications ouverts



Documents pareils
Remote Method Invocation (RMI)

RMI. Remote Method Invocation: permet d'invoquer des méthodes d'objets distants.

RMI le langage Java XII-1 JMF

Remote Method Invocation en Java (RMI)

Intergiciel - concepts de base

Calcul Parallèle. Cours 5 - JAVA RMI

Remote Method Invocation Les classes implémentant Serializable

Java - RMI Remote Method Invocation. Java - RMI

Java RMI. Arnaud Labourel Courriel: Université de Provence. 8 mars 2011

Programmation répartie RPC & RMI

Institut Supérieur de Gestion. Cours pour 3 ème LFIG. Java Enterprise Edition Introduction Bayoudhi Chaouki

Systèmes répartis. Fabrice Rossi Université Paris-IX Dauphine. Systèmes répartis p.1/49

Java DataBaseConnectivity

Projet gestion d'objets dupliqués

Architectures n-tiers Intergiciels à objets et services web

Initiation à JAVA et à la programmation objet.

Plan du cours. Autres modèles pour les applications réparties Introduction. Mode de travail. Introduction

Java Naming and Directory Interface

2 Chapitre 1 Introduction

Quelques patterns pour la persistance des objets avec DAO DAO. Principe de base. Utilité des DTOs. Le modèle de conception DTO (Data Transfer Object)

Introduction aux applications réparties

Le passage à l échelle de serveur J2EE : le cas des EJB

TP1 : Initiation à Java et Eclipse

Institut Supérieure Aux Etudes Technologiques De Nabeul. Département Informatique

Compte Rendu d intégration d application

24/11/2011. Cours EJB/J2EE Copyright Michel Buffa. Plan du cours. EJB : les fondamentaux. Enterprise Java Bean. Enterprise Java Bean.

Modèle client-serveur Plan. Modèle client-serveur. Modèle client-serveur définition. Modèle client-serveur communication par messages.

Généralités sur le Langage Java et éléments syntaxiques.

Le modèle client-serveur

Etude critique de mécanismes de sécurité pour l architecture Jini

Pour signifier qu'une classe fille hérite d'une classe mère, on utilise le mot clé extends class fille extends mère

Mise en œuvre des serveurs d application

.NET remoting. Plan. Principes de.net Remoting

Application web de gestion de comptes en banques

Programme «Analyste Programmeur» Diplôme d état : «Développeur Informatique» Homologué au niveau III (Bac+2) (JO N 176 du 1 août 2003) (34 semaines)

Chapitre 2. Classes et objets

1. Introduction à la distribution des traitements et des données

[APPLICATON REPARTIE DE VENTE AUX ENCHERES]

WEA Un Gérant d'objets Persistants pour des environnements distribués

Services OSI. if G.Beuchot. Services Application Services Présentation - Session Services Transport - Réseaux - Liaison de Données - Physique

Formation en Logiciels Libres. Fiche d inscription

Environnements de Développement

Cours intensif Java. 1er cours: de C à Java. Enrica DUCHI LIAFA, Paris 7. Septembre Enrica.Duchi@liafa.jussieu.fr

GEI 465 : Systèmes répartis

Développement, déploiement et sécurisation d'applications JEE

Principes. 2A-SI 3 Prog. réseau et systèmes distribués 3. 3 Programmation en CORBA. Programmation en Corba. Stéphane Vialle

Serveur d'application Client HTML/JS. Apache Thrift Bootcamp

NFP111 Systèmes et Applications Réparties

Description de la formation

Services Réseaux - Couche Application. TODARO Cédric

Architecture Orientée Service, JSON et API REST

Architecture JEE. Objectifs attendus. Serveurs d applications JEE. Architectures JEE Normes JEE. Systèmes distribués

Cours 1: Java et les objets

Introduction à la plateforme J2EE

Introduction à Java. Matthieu Herrb CNRS-LAAS. Mars

Architecture applicative et Cartographie

Plan du cours. Historique du langage Nouveautés de Java 7

Manuel d implémentation des Web Services Sous Axis1 et Axis2/Tomcat/linux. Par Pr Bouabid EL OUAHIDI

Java pour le Web. Cours Java - F. Michel

Internets. Informatique de l Internet: le(s) Internet(s) Composantes de l internet R3LR RENATER

Java et les bases de données: JDBC: Java DataBase Connectivity SQLJ: Embedded SQL in Java. Michel Bonjour

Evaluation Idéopass Cahier d analyse technique

Le MSMQ. Version 1.0. Pierre-Franck Chauvet

Introduction aux intergiciels

Architectures web/bases de données

ORACLE 10G DISTRIBUTION ET REPLICATION. Distribution de données avec Oracle. G. Mopolo-Moké prof. Associé UNSA 2009/ 2010

Corrigé des exercices sur les références

Module BD et sites WEB

JADE : Java Agent DEvelopment framework. Laboratoire IBISC & Départ. GEII Université & IUT d Evry nadia.abchiche@ibisc.univ-evry.

Encapsulation. L'encapsulation consiste à rendre les membres d'un objet plus ou moins visibles pour les autres objets.

JOnAS Day 5.1. Clustering

OS Réseaux et Programmation Système - C5

Cours CCNA 1. Exercices

Patrons de Conception (Design Patterns)

Programmation Web. Introduction

INTRODUCTION A JAVA. Fichier en langage machine Exécutable

Premiers Pas en Programmation Objet : les Classes et les Objets

Serveurs de noms Protocoles HTTP et FTP

Java c est quoi? Java. Java. Java : Principe de fonctionnement 31/01/ Vue générale 2 - Mon premier programme 3 - Types de Programme Java

Administration de systèmes

4. Utilisation d un SGBD : le langage SQL. 5. Normalisation

Intégration d'applications à "gros grain" Unité d'intégration : le "service" (interface + contrat)

Page 1 sur 5 TP3. Thèmes du TP : l la classe Object. l Vector<T> l tutorial Interfaces. l Stack<T>

Gestion distribuée (par sockets) de banque en Java

Messagerie asynchrone et Services Web

Avant-propos 1. Avant-propos Organisation du guide À qui s'adresse ce guide?...4

PLATE-FORME DE CLOUD COMPUTING SLAPOS. Intégration d applications

Outils, langage et approche Android Une introduction. Nicolas Stouls lyon.fr

«clustering» et «load balancing» avec Zope et ZEO

Formation Webase 5. Formation Webase 5. Ses secrets, de l architecture MVC à l application Web. Adrien Grand <jpountz@via.ecp.fr> Centrale Réseaux

Implémentation des SGBD

Auto-évaluation Programmation en Java

WEB & DÉVELOPPEMENT LES BASES DU WEB LE LANGAGE HTML FEUILLES DE STYLES CSS HISTORIQUE D INTERNET ET DU WEB LES DIFFÉRENTS LANGAGES

NFP 121. Java et les Threads. Présentation : Thierry Escalarasse Mai 2007

Chapitre I Notions de base et outils de travail

Solutions de gestion de la sécurité Livre blanc

Proxy et reverse proxy. Serveurs mandataires et relais inverses

INITIATION AU LANGAGE JAVA

Architectures en couches pour applications web Rappel : Architecture en couches

et Groupe Eyrolles, 2006, ISBN :

Transcription:

Conception de serveurs d'applications ouverts Stéphane Frénot 3 Un modèle d'exécution standard Application Stéphane Frénot 4 1

Répartition "horizontale" d'une application Application de Présentation Application de traitement Application de Stéphane Frénot 5 Répartition d'une application : e- Client de présentation Serveur Web traitement données mozilla Http html Apache php php_jdbc Mysql Client de présentation requêtes web présentation traitements données mozilla apache tomcat jonas oracle Http html Connecteur jk2 RMI Interface Java Jdbc Sql Stéphane Frénot 6 2

Répartition "verticale" d'une application Application de Application traitement de Application traitement de Présentation Application de Application traitement de Application traitement de traitement Application de Application de Application de Stéphane Frénot 7 présentation traitements données présentation traitements Client de présentation Proxy de répartition de charge Moniteur Transactionnel données présentation traitements présentation traitements données Stéphane Frénot 8 3

La distribution du SE (Processus) Application Clusters : Beowulf, SE distribués : Mach, Mosix... Grid Computing : http://www.gridforum.org Stéphane Frénot 9 La distribution du SE (les données) Application Disques RAID Mémoire partagée Stéphane Frénot 10 4

La distribution du SE (l'affichage) Application Cliente Application Serveur Telnet X11 Ica/Vnc Stéphane Frénot 11 La distribution indépendante du SE Base de données : Répliquées / Réparties Moniteurs transactionnels Web Serveurs d'applications Stéphane Frénot 12 5

Défis pour les systèmes distribués d'une manière générale Modèles Gestion de l'hétérogénéité Ouverture Sécurité Capacité de croissance Gestion des pannes Gestion de la concurrence Gestion de la transparence Stéphane Frénot 13 Modèles de communication C/S : Le client serveur, le modèle de base Evénements : Principes de canaux de communication P2P : les entités d'exécution sont identiques Orienté message : Synchrone/Asynchrone Orienté flux Communication de groupes Espace partagés : tuple space Base de données : jdbc / SQL Liaison ftp Tube unix : IPC Protocoles de vote, 2phase commit Communication de groupe copier/coller des ihm Modèle MVC Jeux on-line multijoueurs Stéphane Frénot 14 6

Modèle de programmation Réseau, Matériel, ==> Langages de programmation (objet) ==> Génie logiciel (composants) ==> Le Middleware Machines virtuelles Plates-formes à composants Interpréteurs Stéphane Frénot 15 Le Client / Serveur la brique de base Stéphane Frénot 16 7

Caractéristiques de la communication InterProcessus Primitives : send/receive Synchrone / Asynchrone Destinataire des messages Fiabilité Validité : même si perte de messages Intégrité : Non corrompu, Sans duplication Ordre : Ordre de l'émetteur TCP / UDP Stéphane Frénot 17 Caractéristiques du modèle client-serveur Notion de service réalisé par un serveur demandé par un client définie par une interface (API) entre client et serveur Communication par messages Requête : paramètre d'appel, spécification du service requis Réponse : résultat, indicateur d'exécution/d'erreur Synchrone : Client et serveurs sont bloqués Avantages Structuré, Protégé (espaces d'exécution distincts), Partagé Stéphane Frénot 18 8

Client / serveur "echo" en java L'appel client : java Client test La chaîne "test" est récupérée par le client ==> Commentaires! ==> Améliorations ==> Trois codes possibles Stéphane Frénot 19 Modèle client/serveur : partage Vu du client Vu du serveur Client requête réponse Serveur Gestion des requêtes (priorité) Exécution du service (séquentielle, concurrent) Mémorisation ou non l'état du client requêtes Sélection File des requêtes Traitement réponses Stéphane Frénot 20 9

Modèle Client-Serveur Gestion des processus Client et serveur exécutent des processus distincts Mise en œuvre par les primitives TCP/IP le client est suspendu (appel synchrone) éventuellement plusieurs requêtes peuvent être traitées concurremment par le serveur parallélisme réel (multiprocesseur) pseudo-parallélisme La concurrence peut prendre plusieurs formes plusieurs processus plusieurs processus légers dans le même espace virtuel Stéphane Frénot 21 Modèle Client-Serveur Protocoles sans état : Chaque requête est indépendante de la suivante http, echo, X11 (à détailler), jdbc/sqlnet, Pas de causalité entre les requêtes Pas d'ordre d'arrivé Le modèle est résistant aux pannes du client et du serveur ==> Il suffit de... Stéphane Frénot 22 10

Serveur / Protocole à état Certaines requêtes dépendent des autres pour un même client Identification, Echange de clés de cryptage, Sélection de Menus Le serveur doit mémoriser la connexion du client Mode connecté : la connexion est identifiée par la socket Mode déconnecté : le protocole doit véhiculer l'information d'identification du client Problèmes : Panne Sécurité Stéphane Frénot 23 Panne du client : Serveur à état : panne Le serveur peut repérer qu'il s'agit du même client Comment? Le client peut "rejouer" toute la session. Panne du serveur Le serveur doit enregistrer les états du clients Notion de journalisation ou de persistance Mais il doit pouvoir ré-identifier le client Le client peut "rejouer" toute la session. Ex : sncf Stéphane Frénot 24 11

Serveur à données rémanentes Les requêtes manipulent des données persistantes accessibles par plusieurs clients Exemple base de données Banque, Bourse L'ordre des requêtes est important : Délais d'internet, Inconsistance des données Exemple :» Crédit --> Débit --> ok» Débit --> Agios --> Crédit --> ok - agios Stéphane Frénot 25 Serveurs inter-dépendant Pour fournir une réponse un serveur dépend d'autre serveurs. Nécessité de synchronisation Panne des serveurs esclaves Transactions, 2PC Stéphane Frénot 26 12

Du client/serveur à la suite... Trois questions à résoudre Comment casser la relation forte entre client et serveur, comment rendre le client indépendant du serveur pour l'appel ==>? Comment éviter au client d'avoir du code non réseau dans son appel ==>? Comment augmenter la performance sur plusieurs machines en parallèles ==>? ==> La solution miracle le middleware Stéphane Frénot 27 Middleware Le middleware est une couche d'interposition entre un client et un service, qui réalise certaines opérations au compte du client ou du serveur Stéphane Frénot 28 13

Répartition d'une application Application de Présentation Middleware Implicite Middleware Explicite Application de traitement Application de Middleware Stéphane Frénot 29 Java - RMI Remote Method Invocation Stéphane Frénot 30 14

Répartition d'une application Application de Présentation Middleware Implicite Middleware Explicite ==> Application de traitement Application de Middleware SGFdistribué Stéphane Frénot 31 Objectif Rendre transparent la manipulation d'objets situés dans un autre espace d'adressage Les appels suivants doivent être transparents, que l'objet soit local ou distant Toto toto=new Toto(); String x=z.calcul(toto); y=z.verifie(x, 30); Stéphane Frénot 32 15

Objectifs RMI est une core API RMI permet de faire interagir des objets situés dans des espaces d'adressage distincts situés sur des machines distinctes RMI repose sur les classes de sérialisation Simple à mettre en oeuvre : Définir l'interface de l'objet distribué (OD) Côté serveur : implémenter l'od et l'attacher à une URL Côté serveur : générer les stubs et skeletons (rmic) et diffuser l'od Côté client : s'attacher à l'od (URL) et l'invoquer Un OD se manipule comme tout autre objet Java Stéphane Frénot 33 Architecture de l'invocation de méthodes Stéphane Frénot 34 16

Points clé Java distingue deux familles d'objets Les objets locaux Les objets distants : ils implantent une interface l'interface étends l'interface marker java.rmi.remote Les passages par référence fonctionnent de la même manière que dans le cas classique Si l'objet passé en référence n'est pas remote, il est sérialisé, sinon le client obtient une référence distante désignée par une interface ==>? Comment un client obtient t'il l'accès au service? Stéphane Frénot 35 Le service de nommage RMI registry : annuaire des services qui tournent sur le serveur distant rmi://host:port/name bind (name, obj) Lie l'objet distant (remote object) à un nom spécifique rebind (name, obj) Lie l'objet distant même s'il existe déjà l'ancien est supprimé unbind (name) Retire l'association entre un nom et un objet distant lookup(url) Renvoie l'objet distant associé à une URL list(url) Renvoie la liste des associations sur la registry spécifiée dans l'url Stéphane Frénot 36 17

Le service Hello : Un service exemple Le serveur reçoit une requête Hello du client Il répond par une chaîne augmentée d'une phrase Client Serveur sayhello("coucou"); "coucou From Server" Stéphane Frénot 37 Le client Le client doit rester "simple" ==> Pas de code non-fonctionnel package rmi; import java.rmi.naming; public class HelloClient { public static void main(string [] arg) throws Exception { HelloIfc hello=(helloifc)naming.lookup("rmi://ares-frenot- 3/"+HelloIfc.class.getName()); String s1="coucou"; String s2=hello.sayhello("coucou"); System.out.println("Envoyé : "+s1); System.out.println("Reçu : "+s2); Stéphane Frénot 38 18

Le serveur reste simple aussi! package rmi; import java.rmi.server.unicastremoteobject; import java.rmi.naming; import java.rmi.remoteexception; public class HelloSrv extends UnicastRemoteObject implements HelloIfc { private static String FROMSERVER; public HelloSrv(String serverpart) throws RemoteException { this.fromserver=serverpart; public String sayhello(string hello){ return hello+this.fromserver; public static void main(string [] arg){ try{ HelloSrv srv=new HelloSrv(" From Server"); Naming.bind(HelloIfc.class.getName(), srv); catch(exception e){ e.printstacktrace(); Stéphane Frénot 39 La création du serveur Remote RemoteObject main RemoteServer HelloIfc UnicastRemoteObject RemoteRef HelloSrv new() UnicastRef export() ServerRef Dispatcher UnicastServerRef export() RemoteStub Remote HelloIfc getstub() RemoteProxy HelloSrv_Stub new() Stéphane Frénot 40 19

Exemple 2: Le gestionnaire de comptes comptes Hashtable Position d'un compte Méthode ajout/retrait/position Stéphane Frénot 41 Exemple (1) Définir l'interface de l'od (Contrat entre le client et le serveur) package banque; public interface Banque extends java.rmi.remote { public void ajouter(string id, double somme)throws java.rmi.remoteexception; public void retirer(string id, double somme)throws java.rmi.remoteexception; public Position position(string id) throws java.rmi.remoteexception; Implante Remote, Lève des RemoteExceptions, Les arguments sont sérialisables Stéphane Frénot 42 20

Exemple (2) Ecrire une implémentation de l'od (1) public class BanqueImpl extends java.rmi.server.unicastremoteobject implements Banque { Hashtable clients; public BanqueImpl(Hashtable clients) throws java.rmi.remoteexception { super(); this.clients = clients; public void ajouter(string id, double somme) throws java.rmi.remoteexception {((Compte)clients.get(id)).ajouter(somme); public void retirer(string id, double somme) throws java.rmi.remoteexception {((Compte)clients.get(id)).retirer(somme); public Position position(string id) throws java.rmi.remoteexception { return ((Compte)clients.get(id)).position(); Stéphane Frénot 43 Exemple (3) Ecrire une implementation de l'od (2) public class Position implements java.io.serializable { public double solde; public Date datederniereoperation; public Position(double solde, Date datederniereoperation) { this.solde = solde; this.datederniereoperation = datederniereoperation; Stéphane Frénot 44 21

Exemple (4) Ecrire une implementation de l'od (3) public class Compte { private Position position; Compte(double solde, Date date) {position = new Position(solde, date); void ajouter(double somme) { position.solde += somme; position.derniereoperation = new Date(); void retirer(double somme) { position.solde -= somme; position.derniereoperation = new Date(); Position position() { return position; Stéphane Frénot 45 Exemple (5) Ecrire un programme enregistrant une instance de l'od public class BanqueServeur { public static void main(string[] args) { Hashtable clients = initcomptesclients(); try { BanqueImpl obj = new BanqueImpl(clients); java.rmi.naming.rebind("//falconet.inria.fr/mabanque", obj); System.out.println("Objet distribue 'Banque' est enregistre"); catch(exception e) { e.printstacktrace(); Stéphane Frénot 46 22

Exemple (6) 1) Compiler les sources javac Position.java Compte.java Banque.java BanqueImpl.java BanqueServeur.java 2) Générer les stub et les skeletons rmic banque.banqueimpl ==> BanqueImpl_Stub.class et BanqueImpl_Skel.class 3) Lancer le RMI registry rmiregistry & 4) Lancer l'od java banque.banqueserveur (ou java -Djava.rmi.server.codebase=http://falconet.inria/codebase banque.banqueserveur) Stéphane Frénot 47 Exemple (7) Ecrire un programme client public class Client { public static void main(string[] args) { try { Banque b = (Banque)java.rmi.Naming.lookup("//falconet.inria.fr/MaBanque"); b.ajouter(args[0], 100.00); b.retirer(args[0], 20.00); Position p = b.position(args[0]); System.out.println("Position au "+p.datederniereoperation+":"+ p.solde); catch(exception e) {e.printstacktrace(); Stéphane Frénot 48 23

Distributed Garbage Collector (DGC) Le DGC interagit avec les GC locaux et utilise un mécanisme de referencecounting Lorsqu'un OD est passé en paramètre à un autre OD ref_count++ Lorsqu'un stub n'est plus référencé weak reference Lorsque le GC du client libère le stub, sa méthode finalize est appelée et informe le DGC ref_count-- Lorsque le nombre de références d'un OD = 0 weak reference Le GC du serveur peut alors libérer l'od Le client doit régulierement renouveler son bail auprès du DGC. Si référence à un OD libérée RemoteException Stéphane Frénot 49 Comparaison objet local / objet distant Définition de l'objet Définit par sa classe de description Définit par une interface de description qui étend Remote Implantation Implanté par la classe Le comportement est implanté par une classe qui implante l'interface «remote» Création Opérateur new Une instance distante est fabriquée avec l'opérateur new. Un objet ne peut pas créer à distance un objet. Accès Un objet est accédé directement par une variable qui le référence Un objet distant est accédé par une variable qui référence un talon d'implantation de l'interface distante Stéphane Frénot 50 24

Comparaison objet local / objet distant Référence Une référence sur un objet pointe directement dans la pile Une «remote référence» est un pointer sur un mandataire (proxy, talon) dans la pile. Ce stub contient les informations qui lui permettent de se connecter à l'objet distant qui contient les implantations des méthodes Référence actives Un objet est considéré vivant si au moins une variable le référence Dans un environnement distribué les MV peuvent «crasher». Un objet distant est actif s'il a été accédé avant une certaines durée de vie (lease period). Si toutes les références distantes ont été explicitement relachées ou si toutes les références distantes ont dépassées leur période de leasing l'objet est disponible pour le GC Finalisation Si un objet implante la méthode finalize(), elle est appelée avant que l'objet soit GC Si un objet distant implante l'interface Unreferenced, la méthode unreferenced de cette interface est invoquée quand toutes les références distantes sont Stéphane Frénot 51 Comparaison objet local / objet distant Garbage collection Quand toutes les références locales sont perdues l'objet est candidat au ramassage Le GC distribué fonctionne avec les GC locaux Exceptions Les exceptions sont soit de type Runtime soit Exception. Le compilateur force le développeur à traiter toutes les exceptions RMI force les programmes à traiter toutes les RemoteExceptions qui peuvent être levées. Stéphane Frénot 52 25

Récupération dynamique de classes JVM Client 8 1 7 Namin g 6 Date Etat 2 4 5 rmiregistr y HTTP D 3 JVM Banque_stub { ajouter(int) retirer(int) Etat etat(date) TCP/IP 9 Banque_skel 10 Banque { ajouter(int) retirer(int) Etat etat(date) Stéphane Frénot 53 Encapsulation http (post) Tunneling HTTP JVM Client Banque { ajouter(int) retirer(int) Etat etat(date) JVM Banque_skel Banque_stub { ajouter(int) retirer(int) Etat etat(date) HTTP HTTPD javarmi.cg i Stéphane Frénot 54 26

Conclusion sur Java RMI Extension du RPC aux objets Permet l'accès homogène à des objets distants Permet d'étendre l'environnement local par chargement dynamique de code Pas de langage séparé de description des composants Limitations Environnement restreint à un langage unique (Java) Pas de services additionnels Duplication d'objets Transactions... Stéphane Frénot 55 Autres s à objets répartis RPC : Remote Procedure Call Interface d'appel c Générateur de stub et skeleton (genrpc) Sun rpc Base pour nfs, nis, rwall, rsh... CORBA 2: La référence Indépendant du langage de programmation Stéphane Frénot 56 27

Stéphane Frénot 57 Activation d'objets distants Rappel (JDK1.1) l objet distant est actif au démarrage du serveur RMI Motivation principe du démon inetd d'unix Le démon rmid démarre une JVM qui sert l'objet distant seulement au moment de l'invocation d'une méthode (à la demande) ou au reboot. JDK1.2 introduit un nouveau package java.rmi.activation un objet activable doit dériver de la classe Activatable un démon RMI rmid qui active les objets à la demande ou au reboot de la machine Info : jdk1.2.2\docs\guide\rmi\activation.html Remarque : l'activation est très utilisée par JINI! didier Donsez Stéphane Frénot 58 28

Créer une implémentation activable La classe doit étendre java.rmi.activation.activable et implémenter l'interface distante La classe doit déclarer un constructeur avec 2 arguments java.rmi.activation.activationid, java.rmi.marshalledobject Stéphane Frénot 59 Créer le programme d'enregistrement Rôle passer l'information nécessaire à l'activation de l'objet activable au démon rmid puis enregistrer l'objet auprès de rmiregistry Descripteur ActivationDesc: description des informations nécessaires à rmid Groupes d'objets activables rmid active une JVM par groupe Les objets du même groupe partagent la même JVM ActivationGroup: représente un groupe d'objets activables ActivationGroupDesc: description d'un groupe ActivationGroupID: identifiant d'un groupe Stéphane Frénot 60 29

Code d'enregistrement Stéphane Frénot 61 Code d'enregistrement 2 Stéphane Frénot 62 30

Répartition d'une application Application de Présentation Middleware Implicite Middleware Explicite RMI Application de traitement Application de Middleware SGFdistribué Stéphane Frénot 63 31