SlideShare une entreprise Scribd logo
1  sur  16
Remote Method Invocation
(RMI)
Elaboré par
Mouelhi Maher
Kaabi Ahmed
MP1-DAM
2013-2014
ISET Radès :
Master en développement d'applications mobiles
Plan
• Introduction
• Partie théorique :
- Origine et Objectifs
- Principes
- Architecture générale
- Architecture interne
- Services
- Echange Client Serveur
• Partie Pratique :
- RMI en pratique
- Démonstration (exemple)
• Conclusion
2
Introduction
Invocation de méthodes à distance:
• Mécanisme qui permet à des objets localisés sur des
machines distantes de s’échanger des messages
(invoquer des méthodes).
Semble simple en théorie...
Mais un peu plus complexe en réalité !!! 3
Partie théorique
RMI : Origine et Objectifs
• Solution (SUN) pour adapter le principe des RPC à la
POO (à partir du JDK 1.1).
• Rendre transparent la manipulation d'objets situés
dans un autre espace d'adressage
• Les appels doivent être transparents que l'objet soit
local ou distant.
• Java RMI permet au programmeur d’exécuter une
méthode distante de la même façon (ou presque)
qu’une méthode locale.
5
RMI : principes
• Outils pour :
– la génération des stub/skeleton,
– l ’enregistrement par le nom,
– l ’activation
• Mono-langage et Multiplateforme: de JVM à JVM (les
données et objets ont la même représentation qqs la JVM)
• Orienté Objet : Les RMIs utilisent le mécanisme standard de
sérialisation de JAVA pour l ’envoi d ’objets.
• Dynamique : Les classes des Stubs et des paramètres peuvent
être chargées dynamiquement via HTTP (http://) ou NFS (file:/)
• Sécurité : un SecurityManager vérifie si certaines opérations
sont autorisés par le serveur
6
Architecture RMI générale
• Le serveur doit d’abord
enregistrer (bind) son nom dans
l’annuaire (Registry)
• Le client récupère les
références du serveur à partir
de son nom auprès de
l’annuaire (lookup).
• La souche (stub) sérialise les
paramètres, l’envoie au
squelette (skeleton) qui invoque
la méthode sur le serveur et
retourne les résultats auprès de
la souche.
7
Architecture interne de RMI (logique)
8
- Souche/squelette : encode/décode les paramètres des méthodes
- Gestionnaire de références : associe les mandataires (Remote) aux références
distantes + ramasse-miettes réparti
- Message : définit la structure des messages, leurs identifiants et l’interaction
requête/réponse
- Transport : transporte un message entre deux machines virtuelles Java
RMI: Services
• Service de résolution de noms (Nommage):
Permet d’enregistrer un Remote sous un nom symbolique
• Service d’activation d’objets:
Permet de n’activer des objets que quand ils sont utilisés
• Ramasse-miettes réparti :
récupération des ressources mémoires inutilisées
9
Echange Client Serveur
• Le client appelle une méthode sur
un OD
• Il appelle une méthode du stub
• Le stub construit un bloc de
données avec
– un identificateur de l’objet distant à
utilise
– une description de la méthode à
appeler
– les paramètres encodés qui doivent
être passés
• Le stub envoie ce bloc de données
au serveur...
• Lorsque un objet de réception
reçoit les données
• Le Squeleton effectue les actions
suivantes :
– décode les paramètres encodés
– situe l ’objet à appeler
– invoque la méthode spécifiée
– capture et encode la valeur de
retour ou l ’exception renvoyée par
l ’appel
– Puis le retourne au client
– ………
10
Partie pratique
Etapes pour développer un système RMI
1. Définir l’interface distante
2. Implémenter l’interface distante
3. Implémenter le client
4. Compiler les fichiers Java
5. Générer le stub du client et le skeleton du serveur
6. Démarrer le serveur d’annuaire (RMI registry)
7. Démarrer le serveur
8. Démarrer le client
12
Démo
Conclusion
• RMI est un puissant mécanisme de
distribution d'objet.
• Implantations alternatives à Java RMI
(open-source)
- NinjaRMI (Berkeley)
- Jeremie (ObjectWeb)
14
Bibliographie
• Cours : Architecture client/serveur
Programmation middleware - Dr. Dimassi J. (ISI)
• Cours: Invocation de Méthode à des Objets
distants Exemple : Java RMI
• Cours: Architecture client-serveur Java RMI
• Cours: Java RMI - Gaël Thomas - Master
Informatique M1 – Spécialité SAR
15
Merci

16

Contenu connexe

Tendances

Telecharger Exercices corrigés PL/SQL
Telecharger Exercices corrigés PL/SQLTelecharger Exercices corrigés PL/SQL
Telecharger Exercices corrigés PL/SQLwebreaker
 
Chapitre 5 classes abstraites et interfaces
Chapitre 5  classes abstraites et interfacesChapitre 5  classes abstraites et interfaces
Chapitre 5 classes abstraites et interfacesAmir Souissi
 
Rapport application web (Spring BOOT,angular4) et mobile(ionc3) gestion des a...
Rapport application web (Spring BOOT,angular4) et mobile(ionc3) gestion des a...Rapport application web (Spring BOOT,angular4) et mobile(ionc3) gestion des a...
Rapport application web (Spring BOOT,angular4) et mobile(ionc3) gestion des a...MOHAMMED MOURADI
 
Java 8 - collections et stream
Java 8 - collections et streamJava 8 - collections et stream
Java 8 - collections et streamFranck SIMON
 
Ecole ESMA : Projet Fin de semestre - Application de gestion d'une école - Di...
Ecole ESMA : Projet Fin de semestre - Application de gestion d'une école - Di...Ecole ESMA : Projet Fin de semestre - Application de gestion d'une école - Di...
Ecole ESMA : Projet Fin de semestre - Application de gestion d'une école - Di...Mehdi Hamime
 
Rapport de projet de conception et de développement
Rapport de projet de conception et de développementRapport de projet de conception et de développement
Rapport de projet de conception et de développementDonia Hammami
 
Cours 3 les objets distants rmi corba
Cours 3 les objets distants rmi corbaCours 3 les objets distants rmi corba
Cours 3 les objets distants rmi corbaMariem ZAOUALI
 
Applications Android - cours 11 : Boites de dialogue
Applications Android - cours 11 : Boites de dialogueApplications Android - cours 11 : Boites de dialogue
Applications Android - cours 11 : Boites de dialogueAhmed-Chawki Chaouche
 
Rapport application chat
Rapport application chatRapport application chat
Rapport application chatTbatou sanae
 
TP1-UML-Correction
TP1-UML-CorrectionTP1-UML-Correction
TP1-UML-CorrectionLilia Sfaxi
 
applications-reparties
applications-repartiesapplications-reparties
applications-repartiesmourad50
 
Chp4 - Diagramme de Séquence
Chp4 - Diagramme de SéquenceChp4 - Diagramme de Séquence
Chp4 - Diagramme de SéquenceLilia Sfaxi
 
Applications Android - cours 12 : Persistance de données SQLite
Applications Android - cours 12 : Persistance de données SQLiteApplications Android - cours 12 : Persistance de données SQLite
Applications Android - cours 12 : Persistance de données SQLiteAhmed-Chawki Chaouche
 

Tendances (20)

Telecharger Exercices corrigés PL/SQL
Telecharger Exercices corrigés PL/SQLTelecharger Exercices corrigés PL/SQL
Telecharger Exercices corrigés PL/SQL
 
Chapitre 5 classes abstraites et interfaces
Chapitre 5  classes abstraites et interfacesChapitre 5  classes abstraites et interfaces
Chapitre 5 classes abstraites et interfaces
 
Cours design pattern m youssfi partie 5 adapter
Cours design pattern m youssfi partie 5 adapterCours design pattern m youssfi partie 5 adapter
Cours design pattern m youssfi partie 5 adapter
 
Rapport application web (Spring BOOT,angular4) et mobile(ionc3) gestion des a...
Rapport application web (Spring BOOT,angular4) et mobile(ionc3) gestion des a...Rapport application web (Spring BOOT,angular4) et mobile(ionc3) gestion des a...
Rapport application web (Spring BOOT,angular4) et mobile(ionc3) gestion des a...
 
Cours design pattern m youssfi partie 4 composite
Cours design pattern m youssfi partie 4 compositeCours design pattern m youssfi partie 4 composite
Cours design pattern m youssfi partie 4 composite
 
Support de cours Spring M.youssfi
Support de cours Spring  M.youssfiSupport de cours Spring  M.youssfi
Support de cours Spring M.youssfi
 
Support JEE Servlet Jsp MVC M.Youssfi
Support JEE Servlet Jsp MVC M.YoussfiSupport JEE Servlet Jsp MVC M.Youssfi
Support JEE Servlet Jsp MVC M.Youssfi
 
Sécurité des Applications Web avec Json Web Token (JWT)
Sécurité des Applications Web avec Json Web Token (JWT)Sécurité des Applications Web avec Json Web Token (JWT)
Sécurité des Applications Web avec Json Web Token (JWT)
 
Java 8 - collections et stream
Java 8 - collections et streamJava 8 - collections et stream
Java 8 - collections et stream
 
Ecole ESMA : Projet Fin de semestre - Application de gestion d'une école - Di...
Ecole ESMA : Projet Fin de semestre - Application de gestion d'une école - Di...Ecole ESMA : Projet Fin de semestre - Application de gestion d'une école - Di...
Ecole ESMA : Projet Fin de semestre - Application de gestion d'une école - Di...
 
Rapport de projet de conception et de développement
Rapport de projet de conception et de développementRapport de projet de conception et de développement
Rapport de projet de conception et de développement
 
Cours 3 les objets distants rmi corba
Cours 3 les objets distants rmi corbaCours 3 les objets distants rmi corba
Cours 3 les objets distants rmi corba
 
Applications Android - cours 11 : Boites de dialogue
Applications Android - cours 11 : Boites de dialogueApplications Android - cours 11 : Boites de dialogue
Applications Android - cours 11 : Boites de dialogue
 
Rapport application chat
Rapport application chatRapport application chat
Rapport application chat
 
TP1-UML-Correction
TP1-UML-CorrectionTP1-UML-Correction
TP1-UML-Correction
 
applications-reparties
applications-repartiesapplications-reparties
applications-reparties
 
Chp4 - Diagramme de Séquence
Chp4 - Diagramme de SéquenceChp4 - Diagramme de Séquence
Chp4 - Diagramme de Séquence
 
Servlets et JSP
Servlets et JSPServlets et JSP
Servlets et JSP
 
Applications Android - cours 12 : Persistance de données SQLite
Applications Android - cours 12 : Persistance de données SQLiteApplications Android - cours 12 : Persistance de données SQLite
Applications Android - cours 12 : Persistance de données SQLite
 
PROJET JAVA BD MySQL
PROJET JAVA BD MySQLPROJET JAVA BD MySQL
PROJET JAVA BD MySQL
 

Similaire à Remote method invocation

Cours 1 les principes de base
Cours 1 les principes de baseCours 1 les principes de base
Cours 1 les principes de baseMariem ZAOUALI
 
Présentation de RMI Java
Présentation de RMI JavaPrésentation de RMI Java
Présentation de RMI JavaZakaria Bouazza
 
Les Web Services en 60 diapos chrono !
Les Web Services en 60 diapos chrono !Les Web Services en 60 diapos chrono !
Les Web Services en 60 diapos chrono !Olivier Le Goaër
 
Initiation à Express js
Initiation à Express jsInitiation à Express js
Initiation à Express jsAbdoulaye Dieng
 
Cours services web_fabrice_mourlin
Cours services web_fabrice_mourlinCours services web_fabrice_mourlin
Cours services web_fabrice_mourlinangeeLee
 
Dw731 g formation-ibm-infosphere-streams-v3-administration
Dw731 g formation-ibm-infosphere-streams-v3-administrationDw731 g formation-ibm-infosphere-streams-v3-administration
Dw731 g formation-ibm-infosphere-streams-v3-administrationCERTyou Formation
 
Javav formation-java-avance-hibernate-webservices
Javav formation-java-avance-hibernate-webservicesJavav formation-java-avance-hibernate-webservices
Javav formation-java-avance-hibernate-webservicesCERTyou Formation
 
intro-tech-web-lp3-jan-21-slides-1-a-9.pdf
intro-tech-web-lp3-jan-21-slides-1-a-9.pdfintro-tech-web-lp3-jan-21-slides-1-a-9.pdf
intro-tech-web-lp3-jan-21-slides-1-a-9.pdfCoumbaLaobNdiaye1
 
Formation d'architecte logiciel AFCEPF
Formation d'architecte logiciel AFCEPFFormation d'architecte logiciel AFCEPF
Formation d'architecte logiciel AFCEPFBoubker ABERWAG
 
Drupal 8, symfony
Drupal 8, symfonyDrupal 8, symfony
Drupal 8, symfonyjeUXdiCode
 
Cours 2 les architectures reparties
Cours 2 les architectures repartiesCours 2 les architectures reparties
Cours 2 les architectures repartiesMariem ZAOUALI
 
Appels de procédures distants (RPC)
Appels de procédures distants (RPC)Appels de procédures distants (RPC)
Appels de procédures distants (RPC)Heithem Abbes
 

Similaire à Remote method invocation (20)

Cours 1 les principes de base
Cours 1 les principes de baseCours 1 les principes de base
Cours 1 les principes de base
 
Présentation de RMI Java
Présentation de RMI JavaPrésentation de RMI Java
Présentation de RMI Java
 
JavaRMI.pdf
JavaRMI.pdfJavaRMI.pdf
JavaRMI.pdf
 
Les Web Services en 60 diapos chrono !
Les Web Services en 60 diapos chrono !Les Web Services en 60 diapos chrono !
Les Web Services en 60 diapos chrono !
 
rmi.pdf
rmi.pdfrmi.pdf
rmi.pdf
 
Les sockets.pptx
Les sockets.pptxLes sockets.pptx
Les sockets.pptx
 
Initiation à Express js
Initiation à Express jsInitiation à Express js
Initiation à Express js
 
Rails 3 au Djangocong
Rails 3 au DjangocongRails 3 au Djangocong
Rails 3 au Djangocong
 
IF-RMI.pdf
IF-RMI.pdfIF-RMI.pdf
IF-RMI.pdf
 
Cours services web_fabrice_mourlin
Cours services web_fabrice_mourlinCours services web_fabrice_mourlin
Cours services web_fabrice_mourlin
 
Support NodeJS avec TypeScript Express MongoDB
Support NodeJS avec TypeScript Express MongoDBSupport NodeJS avec TypeScript Express MongoDB
Support NodeJS avec TypeScript Express MongoDB
 
Dw731 g formation-ibm-infosphere-streams-v3-administration
Dw731 g formation-ibm-infosphere-streams-v3-administrationDw731 g formation-ibm-infosphere-streams-v3-administration
Dw731 g formation-ibm-infosphere-streams-v3-administration
 
Javav formation-java-avance-hibernate-webservices
Javav formation-java-avance-hibernate-webservicesJavav formation-java-avance-hibernate-webservices
Javav formation-java-avance-hibernate-webservices
 
REX Ansible
REX AnsibleREX Ansible
REX Ansible
 
intro-tech-web-lp3-jan-21-slides-1-a-9.pdf
intro-tech-web-lp3-jan-21-slides-1-a-9.pdfintro-tech-web-lp3-jan-21-slides-1-a-9.pdf
intro-tech-web-lp3-jan-21-slides-1-a-9.pdf
 
Formation d'architecte logiciel AFCEPF
Formation d'architecte logiciel AFCEPFFormation d'architecte logiciel AFCEPF
Formation d'architecte logiciel AFCEPF
 
Drupal 8, symfony
Drupal 8, symfonyDrupal 8, symfony
Drupal 8, symfony
 
Cours 2 les architectures reparties
Cours 2 les architectures repartiesCours 2 les architectures reparties
Cours 2 les architectures reparties
 
Appels de procédures distants (RPC)
Appels de procédures distants (RPC)Appels de procédures distants (RPC)
Appels de procédures distants (RPC)
 
spring.pdf
spring.pdfspring.pdf
spring.pdf
 

Plus de Institut supérieur des études technologiques de Radès (9)

Hadoop
HadoopHadoop
Hadoop
 
Base des données réparties
Base des données répartiesBase des données réparties
Base des données réparties
 
Web services
Web servicesWeb services
Web services
 
RIA
RIARIA
RIA
 
Architecture .NET
Architecture .NETArchitecture .NET
Architecture .NET
 
Middleware
MiddlewareMiddleware
Middleware
 
Mécanismes de sécurité(ios & android)
Mécanismes de sécurité(ios & android)Mécanismes de sécurité(ios & android)
Mécanismes de sécurité(ios & android)
 
Interface Definition Language
Interface Definition Language Interface Definition Language
Interface Definition Language
 
Architecture .net
Architecture  .netArchitecture  .net
Architecture .net
 

Remote method invocation

  • 1. Remote Method Invocation (RMI) Elaboré par Mouelhi Maher Kaabi Ahmed MP1-DAM 2013-2014 ISET Radès : Master en développement d'applications mobiles
  • 2. Plan • Introduction • Partie théorique : - Origine et Objectifs - Principes - Architecture générale - Architecture interne - Services - Echange Client Serveur • Partie Pratique : - RMI en pratique - Démonstration (exemple) • Conclusion 2
  • 3. Introduction Invocation de méthodes à distance: • Mécanisme qui permet à des objets localisés sur des machines distantes de s’échanger des messages (invoquer des méthodes). Semble simple en théorie... Mais un peu plus complexe en réalité !!! 3
  • 5. RMI : Origine et Objectifs • Solution (SUN) pour adapter le principe des RPC à la POO (à partir du JDK 1.1). • Rendre transparent la manipulation d'objets situés dans un autre espace d'adressage • Les appels doivent être transparents que l'objet soit local ou distant. • Java RMI permet au programmeur d’exécuter une méthode distante de la même façon (ou presque) qu’une méthode locale. 5
  • 6. RMI : principes • Outils pour : – la génération des stub/skeleton, – l ’enregistrement par le nom, – l ’activation • Mono-langage et Multiplateforme: de JVM à JVM (les données et objets ont la même représentation qqs la JVM) • Orienté Objet : Les RMIs utilisent le mécanisme standard de sérialisation de JAVA pour l ’envoi d ’objets. • Dynamique : Les classes des Stubs et des paramètres peuvent être chargées dynamiquement via HTTP (http://) ou NFS (file:/) • Sécurité : un SecurityManager vérifie si certaines opérations sont autorisés par le serveur 6
  • 7. Architecture RMI générale • Le serveur doit d’abord enregistrer (bind) son nom dans l’annuaire (Registry) • Le client récupère les références du serveur à partir de son nom auprès de l’annuaire (lookup). • La souche (stub) sérialise les paramètres, l’envoie au squelette (skeleton) qui invoque la méthode sur le serveur et retourne les résultats auprès de la souche. 7
  • 8. Architecture interne de RMI (logique) 8 - Souche/squelette : encode/décode les paramètres des méthodes - Gestionnaire de références : associe les mandataires (Remote) aux références distantes + ramasse-miettes réparti - Message : définit la structure des messages, leurs identifiants et l’interaction requête/réponse - Transport : transporte un message entre deux machines virtuelles Java
  • 9. RMI: Services • Service de résolution de noms (Nommage): Permet d’enregistrer un Remote sous un nom symbolique • Service d’activation d’objets: Permet de n’activer des objets que quand ils sont utilisés • Ramasse-miettes réparti : récupération des ressources mémoires inutilisées 9
  • 10. Echange Client Serveur • Le client appelle une méthode sur un OD • Il appelle une méthode du stub • Le stub construit un bloc de données avec – un identificateur de l’objet distant à utilise – une description de la méthode à appeler – les paramètres encodés qui doivent être passés • Le stub envoie ce bloc de données au serveur... • Lorsque un objet de réception reçoit les données • Le Squeleton effectue les actions suivantes : – décode les paramètres encodés – situe l ’objet à appeler – invoque la méthode spécifiée – capture et encode la valeur de retour ou l ’exception renvoyée par l ’appel – Puis le retourne au client – ……… 10
  • 12. Etapes pour développer un système RMI 1. Définir l’interface distante 2. Implémenter l’interface distante 3. Implémenter le client 4. Compiler les fichiers Java 5. Générer le stub du client et le skeleton du serveur 6. Démarrer le serveur d’annuaire (RMI registry) 7. Démarrer le serveur 8. Démarrer le client 12
  • 13. Démo
  • 14. Conclusion • RMI est un puissant mécanisme de distribution d'objet. • Implantations alternatives à Java RMI (open-source) - NinjaRMI (Berkeley) - Jeremie (ObjectWeb) 14
  • 15. Bibliographie • Cours : Architecture client/serveur Programmation middleware - Dr. Dimassi J. (ISI) • Cours: Invocation de Méthode à des Objets distants Exemple : Java RMI • Cours: Architecture client-serveur Java RMI • Cours: Java RMI - Gaël Thomas - Master Informatique M1 – Spécialité SAR 15