Chapitre 7: Architecture CORBA et RIM. D après le cours de Patrick Pleczon

Documents pareils
Introduction à CORBA

Remote Method Invocation (RMI)

Intergiciels pour la répartition CORBA : Common Object Request Broker. Patrice Torguet torguet@irit.fr Université Paul Sabatier

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

Construction d Applications Réparties avec CORBA

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

RMI le langage Java XII-1 JMF

Programmation réseau avec Java. 3/7 RMI, un peu de sécurité et CORBA

Remote Method Invocation en Java (RMI)

Programmation répartie: Objet distribué. CORBA (Common Object Request Broker Architectur)

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

CORBA. (Common Object Request Broker Architecture) Denivaldo LOPES

NFP111 Systèmes et Applications Réparties

Calcul Parallèle. Cours 5 - JAVA RMI

Remote Method Invocation Les classes implémentant Serializable

Programmation répartie RPC & RMI

Composants Logiciels. Le modèle de composant de CORBA. Plan

Dis papa, c est quoi un bus logiciel réparti?

Conception de serveurs d'applications ouverts

Intergiciel - concepts de base

CORBA. (Common Request Broker Architecture)

[APPLICATON REPARTIE DE VENTE AUX ENCHERES]

Programmer en JAVA. par Tama

CORBA haute performance

Introduction à Java. Matthieu Herrb CNRS-LAAS. Mars

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

Auto-évaluation Programmation en Java

INTRODUCTION A JAVA. Fichier en langage machine Exécutable

Package Java.util Classe générique

Programmation Objet Java Correction

Introduction à CORBA

Synchro et Threads Java TM

OpenPaaS Le réseau social d'entreprise

TP1 : Initiation à Java et Eclipse

Cours 9 : Servlet, JSP, corba

Le cadre des Web Services Partie 1 : Introduction

Projet gestion d'objets dupliqués

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

Langage et Concepts de ProgrammationOrientée-Objet 1 / 40

Projet de programmation (IK3) : TP n 1 Correction

Software Engineering and Middleware A Roadmap

Suivant les langages de programmation, modules plus avancés : modules imbriqués modules paramétrés par des modules (foncteurs)

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

OS Réseaux et Programmation Système - C5

Java Naming and Directory Interface

Java Licence Professionnelle CISII,

as Architecture des Systèmes d Information

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

1. Structure d un programme C. 2. Commentaire: /*..texte */ On utilise aussi le commentaire du C++ qui est valable pour C: 3.

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

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)

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

Cours 1: Java et les objets

Structure d un programme et Compilation Notions de classe et d objet Syntaxe

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

Programmation Par Objets

Chapitre 10. Les interfaces Comparable et Comparator 1

Derrière toi Une machine virtuelle!

Java - RMI Remote Method Invocation. Java - RMI

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

TP n 2 Concepts de la programmation Objets Master 1 mention IL, semestre 2 Le type Abstrait Pile

INITIATION AU LANGAGE JAVA

TP Programmation Java / JDBC / Oracle

Tutoriel d installation de Hibernate avec Eclipse

Extension SSO Java. Cette note technique décrit la configuration et la mise en œuvre du filtre de custom SSO Java.

Présentation de Java. Olivier de Pertat IT GROUP

La persistance des données dans les applications : DAO, JPA, Hibernate... COMPIL 2010 francois.jannin@inp-toulouse.fr 1

Étude de l interopérabilité de deux langages de programmation basée sur la machine virtuelle de Java

Objets et Programmation. origine des langages orientés-objet

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

Environnements de développement (intégrés)

Développement Logiciel

Création d une application JEE

API04 Contribution. Apache Hadoop: Présentation et application dans le domaine des Data Warehouses. Introduction. Architecture

Alfstore workflow framework Spécification technique

Exceptions. 1 Entrées/sorties. Objectif. Manipuler les exceptions ;

TD Objets distribués n 3 : Windows XP et Visual Studio.NET. Introduction à.net Remoting

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

Prénom : Matricule : Sigle et titre du cours Groupe Trimestre INF1101 Algorithmes et structures de données Tous H2004. Loc Jeudi 29/4/2004

Initiation à JAVA et à la programmation objet.

Une introduction à Java

Premiers Pas en Programmation Objet : les Classes et les Objets

Threads. Threads. USTL routier 1

PROGRAMMATION PAR OBJETS

Création d un service web avec NetBeans 5.5 et SJAS 9

Programmation Réseau. Sécurité Java. UFR Informatique jeudi 4 avril 13

Programmation client-serveur sockets - RPC

Applet pour visualiser les variables «automate» notifiées

La carte à puce. Jean-Philippe Babau

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

P r ob lé m a t iq u e d e la g é n é r icit é. Pr in cip e d e la g é n é r icit é e n Ja v a ( 1 /3 )

Développement mobile MIDP 2.0 Mobile 3D Graphics API (M3G) JSR 184. Frédéric BERTIN

La base de données XML exist. A. Belaïd

27/11/12 Nature. SDK Python et Java pour le développement de services ACCORD Module(s)

Les structures de données. Rajae El Ouazzani

Corrigé des exercices sur les références

Cours 1 : Introduction. Langages objets. but du module. contrôle des connaissances. Pourquoi Java? présentation du module. Présentation de Java

Une introduction à la technologie EJB (2/3)

Communication inter-processus (IPC) : tubes & sockets. exemples en C et en Java. F. Butelle

Chapitre. La conversion. des données

Transcription:

Chapitre 7: Architecture CORBA et RIM D après le cours de Patrick Pleczon

CORBA Common Object Request Broker Architecture «Bus» logiciel Normalisé par l'omg Basé sur un protocole standard (GIOP : General Inter-ORB Protocol) IIOP (Internet IOP) est la version TCP/IP du protocole Un langage de définition d interface : IDL Intégration de technologies hétérogènes Java, C++, ADA, SmallTalk, Cobol, Des services Object services : persistance, nommage, cycle de vie,... CORBA facilities :impression, messagerie,... 2

CORBA Faciliter la programmation des systèmes distribués: Orienté Objet. Transparence de la localisation des objets. Transparence des accès (local/distant) aux objets. Masquage de l hétérogénéité : des OS des langages Offrir un standard non propriétaire 3

CORBA Objets Applicatifs Common facilities Task man. System man. ORB Naming Events Persistence Life Cycle Properties Transactions Concurrency Licensing Security Externalization Query Relationships Time Trader Common Object Services 4

L ORB Client Objet du serveur Dynamic Invocation Interface IDL Stubs ORB I/F IDL skeleton Object adapter ORB 5

Le langage IDL Un langage de description d interfaces indépendant des langages d implémentation. Des compilateurs génèrent le code client et serveur dans différents langages à partir de l IDL 6

IDL : exemple module Bank { interface Account { exception Overdraft { string reason; }; readonly attribute float balance; void deposit (in float amount); Module = package Attribut=génère 2 accesseurs mais pas de donnée On précise le mode de passage des paramètres : in, out, inout void withdraw (in float amount) raises (Overdraft); attribute string name; }; (...) 7

IDL : exemple (suite) interface AccountManager { Account open (in string name, in float initial_balance); }; void close (in Account account); }; On peut renvoyer une interface 8

IDL : types de base short long unsigned short unsigned long float double char boolean octet any string 9

IDL : héritage Héritage simple ou multiple entre interfaces. Exemple interface CompteRemunere : Compte { attribute short taux; float calculeinterets() }; 10

IDL : autres types constant struct enum union typedef sequence array struct UserAccess { string name; string password; }; typedef sequence<compte> ListeCompte; 11

IDL : génération de code IDL Compilateur IDL Code Client (Stub) Code Serveur (Skeleton) 12

ORB : envoi d une requête Client Objet du serveur requête réponse Dynamic Invocation Interface IDL Stubs ORB I/F IDL skeleton Object adapter ORB 13

ORB : envoi d une requête Client Appel d une méthode sur un objet : i = obj.f(p1, pn) Préparation d un message (marshalling) contenant :. la réf. De l objet de destination. la méthode appelée Stub. ses paramètres Envoi du message vers le serveur Attente de la réponse Réception d un message Décodage (unmarshalling), récupération de :. la réf. De l objet de destination. la méthode appelée. ses paramètres Serveur Recherche l objet correspondant à la référence Appelle la méthode sur l objet avec les paramètres décodés 14

ORB : réception de la réponse i = obj.f(p1, pn) Client Décodage du messagede retour (unmarshalling):. Paramètres out. Retour de la méthode Retour de la méthode locale Serveur Stub Retour de la méthode appelée Encodage (marshalling) des paramètres de retour :. Paramètres out. Retour de la méthode Envoi du message de retour vers le serveur 15

L interface d invocation dynamique Possibilité d appeler des méthodes d un objet serveur sans stub dans le client : La requête est préparée «à la main» : Définition du nom de la méthode et des paramètres. Appel de la requête et récupération «à la main» des paramètres de retour. 16

Les callbacks (1) Permettent à un serveur de notifier un ou des client(s). Exemple: tableur distribué: Serveur 12 Client1 1:modifieCellule(«A2», 15) 2:notifieClient(«A2») Client2 Client3 17

Les callbacks (2): exemple d IDL Interface Tableur { void mofifiecellule(in string cell, in any valeur); void enregistreclient(in ClientTableur clt); }; interface ClientTableur { void notifieclient(in string cell); }; Objet serveur implémenté par le serveur Objet serveur implémenté par le client 18

Callback : les services CORBA L utilisation de services CORBA peut simplifier la gestion des callbacks: Service d événements abonnement à des «topics» push ou pull Service de notification Ajoute des possibilités de filtrage sur le contenu des événements. Serveur 1:modifieCellule(«A2», 15) 2:push(evt) Client1 Client2 3:push(evt) E.S. 19

CORBA/Java Présentation générale Process de développement Description du service de nommage Le compilateur IDL Mapping IDL/Java - code généré Le POA (Portable Object Adapter) Implémentation du serveur par héritage et par délégation Implémentation du client Execution Compléments sur l IDL 20

CORBA/Java - Java IDL CORBA/Java : Mapping CORBA IDL vers Java JAVA IDL est inclus dans le JDK (depuis 1.2) comprend un compilateur IDL : idlj comprend un service de nommage (non persistant ) : tnameserv un service de nommage plus évolué : orbd 21

Process de développement Définir l IDL du serveur. Générer le code Java (stub et skeleton) avec le compilateur IDL. Implémenter le serveur. Implémenter le client. 22

Le service de nommage Permet à un client de retrouver un objet serveur à partir de son nom. Les objets sont référencés par des «composants de noms» comportants : Un nom d enregistrement (ID) Un type d objet (kind) Le service de nommage offre une structure arborescente de type «directory». 23

Le service de nommage (suite) Initial Naming Context DeptX DeptY Perso S1 S1 S2 S3 MonServeur Naming context Name Binding 24

Java IDL - Le compilateur Idlj -fall Hello.idl Hello.idl Compilateur IDL module HelloApp { interface Hello { string sayhello(); oneway void shutdown(); }; }; _HelloStub.java HelloHelper.java HelloOperations.java HelloPOA.java HelloHolder.java Hello.java 25

Mapping IDL/Java IDL Java module package interface interface, classe helper, classe holder constant public static final boolean boolean char, wchar char octet byte string, wstring java.lang.string short, unsigned short short long, unsigned long int long long, unsigned long long long float float double double enum, struct, union class sequence, array array exception class readonly attribute methode d'accès en lecture methods d'accès en lecture et méthode d'accès en readwrite attribute écriture operation methode 26

Code généré par Java IDL Un module IDL correspond à un package Java Toutes les classes générées correspondant à un module sont dans le même package. _HelloStub.java Classe stub de Hello HelloHelper.java Classe Helper de Hello : fournit une méthode «narrow» de conversion des références CORBA HelloHolder.java Classe holder de Hello pour passage de paramètres out et inout HelloOperations.java Interface définissant les opérations. HelloPOA.java Classe skeleton de Hello Hello.java Interface Hello 27

Graphe des classes générées org.omg.corba. Object HelloOperations org.omg.corba.portable. IDLIdentity _org.omg.corba. Portable. ObjectImpl Hello org.omg.corba. portable.invokehandler org.omg.portableserver. Servant HelloPOA _HelloStub 28

Classes Helper Les classes Helper permettent de manipuler les types IDL. Insertion/extraction dans un «Any». Conversion du type CORBA.Object vers les types dérivés (opérateur narrow) Une classe helper est générée pour chaque interface IDL. (...) 29

Classes Helper (suite) package HelloApp; public class HelloHelper { // It is useless to have instances of this class private HelloHelper() { } } public static void write(org.omg.corba.portable.outputstream out, HelloApp.Hello that) {... } public static HelloApp.Hello read(org.omg.corba.portable.inputstream in) { } public static HelloApp.Hello extract(org.omg.corba.any a) {...} public static void insert(org.omg.corba.any a, HelloApp.Hello that) {...} private static org.omg.corba.typecode _tc; synchronized public static org.omg.corba.typecode type() {...} public static String id() { return "IDL:HelloApp/Hello:1.0"; } Renvoie un stub public static HelloApp.Hello narrow(org.omg.corba.object that) throws org.omg.corba.bad_param {...} 30

Classes Holder Java ne supportant que des paramètres «in», les classes Holder permettent le passage de paramètres out ou inout. Il existe des classes Holder pour tous les types de base (ex: ShortHolder). Une classe Holder est générée pour chaque interface IDL.. (...) 31

Classes Holder (suite) package HelloApp; public final class HelloHolder implements org.omg.corba.portable.streamable{ // instance variable public HelloApp.Hello value; // constructors public HelloHolder() { this(null); } public HelloHolder(HelloApp.Hello arg) { value = arg; } public void _write(org.omg.corba.portable.outputstream out) {...} public void _read(org.omg.corba.portable.inputstream in) {...} public org.omg.corba.typecode _type() {...} } 32

Le POA (Portable Object Adapter) Object Adapter: Mécanisme qui permet de relier une référence objet utilisée dans une requête avec le code d exécution. POA: défini dans la spécification CORBA. Assure la portabilité des Implémentations entre ORB. Permet la persistance d identités. Permet la gestion du cycle de vie des objets: Création, activation, passivation, suppression. 33

Implémentation par héritage des classes du serveur La classe d implémentation dérive de la classe TypePOA : Ex : class HelloServant extends HelloPOA Elle implémente les méthodes de l IDL. 34

Implémentation du serveur // HelloServer.java import org.omg.cosnaming.*; import org.omg.cosnaming.namingcontextpackage.*; import org.omg.corba.*; import org.omg.portableserver.*; import org.omg.portableserver.poa; import java.util.properties; class HelloImpl extends HelloPOA { private ORB orb; public void setorb(orb orb_val) { orb = orb_val; } public String sayhello() { return "\nhello world!!\n"; } public void shutdown() { orb.shutdown(false); } } Défini dans l IDL (...) 35

Implémentation du serveur (suite) public class HelloServer { public static void main(string args[]) { try{ // initialisation de l ORB et création de l objet servant ORB orb = ORB.init(args, null); POA rootpoa = POAHelper.narrow (orb.resolve_initial_references("rootpoa")); rootpoa.the_poamanager().activate(); HelloImpl helloimpl = new HelloImpl(); helloimpl.setorb(orb); 36

Implémentation du serveur (suite) // enregistrement de l objet dans le naming service org.omg.corba.object ref = rootpoa.servant_to_reference(helloimpl); Hello href = HelloHelper.narrow(ref);. org.omg.corba.object objref = orb.resolve_initial_references("nameservice"); NamingContextExt ncref = NamingContextExtHelper.narrow(objRef); String name = "Hello"; NameComponent path[] = ncref.to_name( name ); ncref.rebind(path, href); System.out.println("HelloServer ready and waiting..."); orb.run(); } catch (Exception e) { System.err.println("ERROR: " + e); e.printstacktrace(system.out); } System.out.println("HelloServer Exiting..."); } } 37

Implémentation du client import HelloApp.*; import org.omg.cosnaming.*; import org.omg.corba.*; public class HelloClient { public static void main(string args[]) { try{ // create and initialize the ORB ORB orb = ORB.init(args, null); // get the root naming context org.omg.corba.object objref = orb.resolve_initial_references("nameservice"); NamingContext ncref = NamingContextHelper.narrow(objRef); (...) 38

Implémentation du client (suite) // resolve the Object Reference in Naming NameComponent nc = new NameComponent("Hello", ""); NameComponent path[] = {nc}; Hello helloref = HelloHelper.narrow(ncRef.resolve(path)) // call the Hello server object and print results String hello = helloref.sayhello(); System.out.println(hello); } } } catch (Exception e) { System.out.println("ERROR : " + e) ; e.printstacktrace(system.out); } 39

Execution Lancer le service de nommage: tnameserv ou ordb Lancer le serveur Lancer le client 40

Compléments sur l IDL : les structures Exemple IDL : struct PersonStruct { string nom; string prenom; short age; } Code Java généré final public class PersonStruct { // instance variables public String nom; public String prenom; public short age; // constructors public PersonStruct () {} public PersonStruct (String nom, String prenom, short age) {...} } final public class PersonStructHolder... 41

Compléments sur l IDL : les séquences Exemple IDL : typedef sequence<personstruct> PersonSeq; Code Java généré La séquence est implémentée par un tableau. Une classe holder est générée par type de séquence. final public class PersonSeqHolder { public PersonStruct[] value; } public PersonSeqHolder() {}; public PersonSeqHolder(PersonStruct[] initial) {...}; public void _read(org.omg.corba.portable.inputstream i) {...} public void _write(org.omg.corba.portable.outputstream o) {...} public org.omg.corba.typecode _type() {...} 42

Compléments sur l IDL : le type Any Le type Any permet de contenir une donnée de type IDL quelconque. Lorsqu une donnée est insérée dans un Any, le type de la donnée est inséré dans le champ typecode (identification du type IDL). void insert_xxx(xxx x) L extraction de la donnée renvoie une exception si le type extrait ne correspond pas au typecode de l any. XXX extract_xxx() throws BAD_OPERATION Les anys sont créés par le singleton ORB org.omg.corba.any any = orb.create_any(); 43

Compléments sur l IDL : les exceptions 2 types d exceptions : User et System. Java.lang.exception org.omg.corba.userexception java.lang.runtimeexception MyException User Exception = classe Java générée org.omg.corba.systemexception 44

Java RMI Présentation générale Principes de communication Process de développement avec RMI Execution Chargement des stubs/sécurité Exemple 45

RMI Remote Method Invocation Solution 100% Java client et serveur Protocole basé sur IIOP (RMI-IIOP) Possibilité de choisir un protocole de transport (RMIClientSocketFactory) Passage d'objets par valeur Utilise la sérialisation Peu de services Nommage Support de persistance et d activation Non standard Modèle de programmation transparent Contient un Distributed Garbage Collector (DGC) 46

RMI : communication Utilisation de stubs et de skeletons générés comme pour CORBA. Client Stubs Objet du serveur skeleton 47

Process de développement avec RMI Définir l interface distante et la dériver de l interface java.rmi.remote. Chaque méthode doit déclarer l exception java.rmi.remoteexception. Implémenter l interface dans une classe dérivée de java.rmi.unicastremoteobject. Compiler la classe serveur. Générer les stub et skeleton avec rmic. rmic [options] myserverclass Ecrire le code du client. Compiler le client. 48

Execution avec RMI Lancer le serveur d enregistrement RMI. rmiregistry Démarrer le serveur. Le serveur doit : Créer un (des) instances d objets RMI. s enregistrer auprès du RMI registry avec la classe java.rmi.naming. Démarrer le client Le client doit se connecter à l objet serveur en utilisant le RMI registry. 49

Chargement des stubs/sécurité Les stubs des objets distants peuvent être chargés du serveur. Lors de la connection du client sur le serveur, le serveur indique au client l URL à utiliser pour charger le stub. Nécessite un loader de classes particulier (RMIClassLoader) et un manager de sécurité particulier (RMISecurityManager) 50

Exemple RMI : interface remote package examples.hello; import java.rmi.remote; import java.rmi.remoteexception; public interface Hello extends Remote { String sayhello() throws RemoteException; } 51

Exemple de serveur RMI import java.rmi.remote; import java.rmi.naming; import java.rmi.remoteexception; import java.rmi.rmisecuritymanager; import java.rmi.server.unicastremoteobject; public class HelloImpl extends UnicastRemoteObject implements Hello { public HelloImpl() throws RemoteException { super(); } public String sayhello() { return "Hello World!"; } ( ) 52

Exemple de serveur RMI (suite) public static void main(string args[]) { // Create and install a security manager if (System.getSecurityManager() == null) { System.setSecurityManager(new RMISecurityManager()); } try { HelloImpl obj = new HelloImpl(); // Bind this object instance to the name "HelloServer" Naming.rebind("//serverHost/HelloServer", obj); System.out.println("HelloServer bound in registry"); } catch (Exception e) { System.out.println("HelloImpl err: " + e.getmessage()); e.printstacktrace(); } 53

Exemple de client RMI // Applet HelloApplet Hello obj = null;... public void init() { try { obj = (Hello)Naming.lookup("//" + getcodebase().gethost() + "/HelloServer"); message = obj.sayhello(); } catch (Exception e) { System.out.println("HelloApplet exception: " + e.getmessage()); e.printstacktrace(); } }... 54

Lancement du serveur Au lancement du serveur, il faut préciser: L emplacement des classes stub. L emplacement du fichier de sécurité. java -classpath "C:\myprojects\proj1\myclasses" -Djava.rmi.server.codebase="file:\myprojects\proj1\myclasses /" -Djava.security.policy="C:\myprojects\proj1\TradeServer\policy.txt" HelloServer exemple de fichier de sécutité: grant { // Allow everything permission java.security.allpermission; }; 55

Prise en compte des firewalls Un client RMI essaie de se connecter au serveur par un socket. Si la connexion est refusée, il tentera automatiquement d envoyer la requête par HTTP (post). Si le serveur RMI reçoit une requête HTTP post, il répond automatiquement avec le protocole HTTP. Ceci est complètement transparent (aucune configuration particulière nécessaire). 56

Comparaison CORBA/RMI Protocole IIOP RMP ou IIOP Indépendance/langage oui non Passage d'objets par valeur CORBA 3.0 oui Passage de paramètres in, out, inout in Performances + - Facilité de mise en œuvre - + Gestion de transactions par CORBA OTS non Services + - 57