<< De la méthode, toujours
|
|
- Marc Paris
- il y a 7 ans
- Total affichages :
Transcription
1 << De la méthode, toujours >> RMI, les bases Cours "Réseaux et systèmes répartis" NFP 214 par Jacques LAFORGUE version du 04/02/2010 slide numéro 1
2 Définitions RMI = Remote Method Invocation RMI est une solution pure Java permettant de réaliser l invocation à distance de méthode d objet Elle est accessible à travers les classes et interfaces prédéfinies d API Java Ces API sont : java.rmi java.rmi.server java.rmi.registry Ainsi, les composants de l orb RMI sont : Les API Le compilateur IDL L annuaire ou adaptateur Les descriptions des API qui suivent sont volontairement incomplètes afin de décrire l essentiel. Cours "Systèmes et réseaux répartis" NFP 214 par Jacques LAFORGUE (jacques.laforgue@neuf.fr) version du 04/02/2010 slide numéro 2
3 Les API : java.rmi.* class Naming Cette classe gère le service de nommage static void bind(string name, Remote obj) Binds the specified name to a remote object. static String[] list(string name) Returns an array of the names bound in the registry. static Remote lookup(string name) Returns a reference, a stub, for the remote object associated with the specified name. static void rebind(string name, Remote obj) Rebinds the specified name to a new remote object. static void unbind(string name) Destroys the binding for the specified name that is associated with a remote object. class RMISecurityManager Cette classe gère les autorisations d'utilisation de Java pour RMI System.setSecurityManager(new RMISecurityManager()); Interface Remote Utilisé dans les interfaces (IDL) Cours "Systèmes et réseaux répartis" NFP 214 par Jacques LAFORGUE (jacques.laforgue@neuf.fr) version du 04/02/2010 slide numéro 3
4 Exemple de RMISecurityManager Les RMIs propose un gestionnaire de sécurité RMISecurityManager qui par défaut interdit tout ce qu'un SecurityManager peut interdire, sauf la définition de classe. Pour permettre plus de chose il faut écrire son propre gestionnaire de sécurité héritant de RMISecurityManager. Exemple d'un serveur de calcul de complexe ou toutes les classes sont chargées dynamiquement par le client. package test.rmi; import java.rmi.*; import java.util.*; public class ComplexCompute public static void main(string [] args) throws Exception Properties p=system.getproperties(); p.put("java.rmi.server.codebase"," System.setProperties(p); System.setSecurityManager(new RMISecurityManager()); ComplexOps obj = (ComplexOps) Naming.lookup("//"+ args[0]+ ":10003/ComplexOps"); Complex c1 = obj.newcomplex(1,1); Complex c2 = obj.newcomplex(2,2); Complex c3 = obj.addcomplex(c1,c2); Complex c4 = obj.multcomplex(c1,c2); System.out.println(c1 + " + " + c2 + " = " + c3); System.out.println(c1 + " * " + c2 + " = " + c4); Cours "Systèmes et réseaux répartis" NFP 214 par Jacques LAFORGUE (jacques.laforgue@neuf.fr) version du 04/02/2010 slide numéro 4
5 Les API : java.rmi.server.* class UnicastRemoteObject Cette classe gère tout ce qui concerne un "servant" pour RMI protected UnicastRemoteObject() Creates and exports a new UnicastRemoteObject object using an anonymous port. protected UnicastRemoteObject(int port) Creates and exports a new UnicastRemoteObject object using the particular supplied port. protected UnicastRemoteObject(int port, RMIClientSocketFactory csf, RMIServerSocketFactory ssf) Creates and exports a new UnicastRemoteObject object using the particular supplied port and socket factories. static RemoteStub exportobject(remote obj) Exports the remote object to make it available to receive incoming calls using an anonymous port. static Remote exportobject(remote obj, int port) Exports the remote object to make it available to receive incoming calls, using the particular supplied port. static Remote exportobject(remote obj, int port, RMIClientSocketFactory csf, RMIServerSocketFactory ssf) Exports the remote object to make it available to receive incoming calls, using a transport specified by the given socket factory. static boolean unexportobject(remote obj, boolean force) Removes the remote object, obj, from the RMI runtime. Cours "Systèmes et réseaux répartis" NFP 214 par Jacques LAFORGUE (jacques.laforgue@neuf.fr) version du 04/02/2010 slide numéro 5
6 Deux façons de créer un objet distribué par héritage : via les constructeur de UnicastRemoteObejct (voir l'exemple RMI) par agrégation : via la méthode exportobject (voir l'exemple RMI) Cours "Systèmes et réseaux répartis" NFP 214 par Jacques LAFORGUE (jacques.laforgue@neuf.fr) version du 04/02/2010 slide numéro 6
7 Les API : java.rmi.registry (1/2) class LocateRegistry Cette classe gère en local d'un "serveur" le service de nommage static Registry createregistry(int port) Creates and exports a Registry on the local host that accepts requests on the specified port. static Registry createregistry(int port, RMIClientSocketFactory csf, RMIServerSocketFactory ssf) Creates and exports a Registry on the local host that uses custom socket factories for communication with that registry. static Registry getregistry() Returns a reference to the the remote object Registry for the local host on the default registry port of static Registry getregistry(int port) Returns a reference to the the remote object Registry for the local host on the specified port. static Registry getregistry(string host) Returns a reference to the remote object Registry on the specified host on the default registry port of static Registry getregistry(string host, int port) Returns a reference to the remote object Registry on the specified host port.static Registry getregistry(string host, int port, RMIClientSocketFactory csf) Returns a locally created remote reference to the remote object Registry on the specified host and port. Cours "Systèmes et réseaux répartis" NFP 214 par Jacques LAFORGUE (jacques.laforgue@neuf.fr) version du 04/02/2010 slide numéro 7
8 Les API : java.rmi.registry (2/2) Interface Registry Cette interface permet de créer une autre implémentation du service de nommage void bind(string name, Remote obj) Binds a remote reference to the specified name in this registry. String[] list() Returns an array of the names bound in this registry. Remotelookup(String name) Returns the remote reference bound to the specified name in this registry. Void rebind(string name, Remote obj) Replaces the binding for the specified name in this registry with the supplied remote reference. Void unbind(string name) Removes the binding for the specified Cours "Systèmes et réseaux répartis" NFP 214 par Jacques LAFORGUE (jacques.laforgue@neuf.fr) version du 04/02/2010 slide numéro 8
9 Les packages de javax javax.rmi javax.rmi.corba Ces deux packages contiennent tous les éléments permettant de mettre en œuvre RMI-IIOP (AD) Cours "Systèmes et réseaux répartis" NFP 214 par Jacques LAFORGUE version du 04/02/2010 slide numéro 9
10 Le compilateur IDL En RMI, le compilateur IDL est une fourniture du JDK java que l on trouve dans le répertoire bin (exemple sur le JEE 1.5 : C:\Sun\AppServer\jdk\bin) Il est donc accessible via le PATH La syntaxe : rmic <package>.<nom classe OD> La commande rmic permet de générer les squelettes (skelton) et les amorces (stub) RMI. <nom classe OD> est le nom de la classe de l OD (qui hérite de UnicastRemoteObjetct et surtout hérite d une interface dans laquelle sont décrites les méthodes distantes de l OD Il est à noter que depuis la version 1.5, il est inutile d utiliser la commande rmic car java prend en charge nativement et dynamiquement la création des objets de classes Stub et Skeleton. Nous verrons que en RMI-IIOP, il est indispensable d utiliser la commande rmic (rmic iiop ) Cours "Systèmes et réseaux répartis" NFP 214 par Jacques LAFORGUE (jacques.laforgue@neuf.fr) version du 04/02/2010 slide numéro 10
11 L adaptateur d objet (1/2) Il existe 3 façons d'exécuter un adaptateur RMI : en utilisant la classe prédéfinie sun.rmi.registry.registryimpl exemple: java -classpath "packages" sun.rmi.registry.registryimpl 9999 avantages : un meilleur pilotage du classpath, se lance à l'extérieur inconvénients : doit toujours être lancé avant tous les autres programmes serveur, peut être obsolète (confusion avec java.rmi.registry.registryimpl), le port est un paramètre de commande OS en utilisant la commande rmiregistry (c'est un exe qui utilise le $CLASSPATH) exemple: rmiregistry 9999 avantages : façon récente d'exécuter un adaptateur à l'extérieur inconvénients : pas de pilotage du classpath, variable d'environnement, le port est un paramètre de commande OS en créant l'adaptateur dans le code (le classpath de la JVM) exemple : try LocateRegistry.createRegistry(9999); catch(exception l_ex); avantages : intégrer au code, le port peut être précisé par configuration (fichier, properties, ), inconvénients : intégrer au code, fonction du classpath de la JVM, nécessite un programme serveur maître devant être exécuté avant tous les autres Cours "Systèmes et réseaux répartis" NFP 214 par Jacques LAFORGUE (jacques.laforgue@neuf.fr) version du 04/02/2010 slide numéro 11
12 L adaptateur d objet (2/2) On passe en paramètre du lancement le numéro de port sur lequel les clients devront se connecter. Ce numéro doit être libre (voir votre administrateur système). Pour vos applications sur vos PC vous pouvez prendre par exemple un numéro élevé On peut exécuter plusieurs adaptateurs sur une même machine du moment qu ils s exécutent sur des ports différents L adresse de connexion à un adaptateur rmi est : rmi://host:port où host est l adresse IP de la machine sur lequel s exécute l adaptateur port est le port utiliser par l adaptateur rmi est le nom du prôtocole de connexion utilisé (on peut ne pas le mettre: par défaut rmi) Remarque: en ne le mettant pas on peut par une configuration général utiliser un autre ORB On ne peut pas enregistrer un OD dans un adaptateur sur une machine distante depuis une autre machine. Cours "Systèmes et réseaux répartis" NFP 214 par Jacques LAFORGUE (jacques.laforgue@neuf.fr) version du 04/02/2010 slide numéro 12
13 Le Socket Factory RMI (1/4) Le Socket Factory de RMI permettant de traiter les requêtes des clients est de niveau "static" Le port d'écoute est soit déterminée par défaut (le premier libre), Le même port pour une même JVM Un par JVM soit imposé UnicastRemoteObject super( port ) le port doit être libre on peut associer plusieurs ports permet de sécuriser l'utilisation des objets distribuées via les firewalls Cours "Systèmes et réseaux répartis" NFP 214 par Jacques LAFORGUE (jacques.laforgue@neuf.fr) version du 04/02/2010 slide numéro 13
14 Le Socket Factory RMI (2/4) super() les ports sont alloués par le système automatiquement pas de politique ciblé de sécurité Un seul serveur de socket par JVM bind bind bind bind Cours "Systèmes et réseaux répartis" NFP 214 par Jacques LAFORGUE version du 04/02/2010 slide numéro 14
15 Le Socket Factory RMI (3/4) super(port) les ports sont déterminés par l'administrateur politique ciblé de sécurité Autant de serveur de socket que de port différent Attention au conflit de port pour une même machine bind bind bind bind Cours "Systèmes et réseaux répartis" NFP 214 par Jacques LAFORGUE version du 04/02/2010 slide numéro 15
16 Il semble que le schéma décrit la politique suivante : dans la JVM1 tous les objets distribués s'exécutent sur le même port (9101) dans la JVM2 chaque objet distribué s'exécute sur un port dfférent. Cours "Systèmes et réseaux répartis" NFP 214 par Jacques LAFORGUE (jacques.laforgue@neuf.fr) version du 04/02/2010 slide numéro 16
17 Le Socket Factory RMI (4/4) Dans l'exemple NFP214_Exemple_009_ExempleRMI_Security, on instrumente en la redéfinissant, les classes : RMIClientSocketFactory RMIServerSocketFactory Lors du bind, la classe RMIClientSocketFactory est envoyé (par sérialisation) à l'adaptateur qui l'enverra ensuite (par sérialisation) au client lors de sa connexion. Son interface : Socket createsocket(host,port) La classe RMIServerSocketFactory est utilisée que par le serveur. Son interface: ServerSocket createserversocket(port) Pour obliger le client à utiliser des ports locaux définis (et non aléatoire) il est nécessaire de redéfinir sa propre politique de socket factory comme cela est décrit dans l'exemple (voir MyRMISocketFactory.java) Cours "Systèmes et réseaux répartis" NFP 214 par Jacques LAFORGUE (jacques.laforgue@neuf.fr) version du 04/02/2010 slide numéro 17
18 Création d'un objet distribué en RMI deux façons : par héritage par construction création par héritage : la classe UnicastRemoteObject ne pas oublier super() ou super(port),. la meilleur façon de faire création par construction la méthode exportobject de UnicastRemoteObject possède les mêmes signatures que les constructeurs avec en plus l'objet qui implémente les méthodes distante: public static RemoteStub exportobject(remote obj, ) Attention : dans ce cas, il faut générer le stub avec la commande rmic. Cours "Systèmes et réseaux répartis" NFP 214 par Jacques LAFORGUE (jacques.laforgue@neuf.fr) version du 04/02/2010 slide numéro 18
19 Mise en œuvre RMI (1/5) Description dynamique de la mise en œuvre RMI des composants logiciels du serveur rmiregistry Naming 9105 NOM_OD 3 Naming NOM_OD 1 Client Serveur 2 Stub Sekelton 2 JVM Client JVM Serveur Cours "Systèmes et réseaux répartis" NFP 214 par Jacques LAFORGUE (jacques.laforgue@neuf.fr) version du 04/02/2010 slide numéro 19
20 Mise en œuvre RMI (2/5) 1 - L'objet serveur s'enregistre auprès du Naming de sa machine (méthode rebind) 2 - L objet skeleton est créé par le Naming, il crée le port de communication et maintient une référence vers l'objet serveur 3 - Le Naming enregistre l'objet serveur, et le port de communication utilisé dans du serveur de noms Cours "Systèmes et réseaux répartis" NFP 214 par Jacques LAFORGUE (jacques.laforgue@neuf.fr) version du 04/02/2010 slide numéro 20
21 Mise en œuvre RMI (3/5) Description dynamique de la mise en œuvre RMI des composants logiciels du client Cours "Systèmes et réseaux répartis" NFP 214 par Jacques LAFORGUE version du 04/02/2010 slide numéro 21
22 Mise en œuvre RMI (4/5) 4 - L'objet client fait appel au Naming pour localiser l'objet serveur (méthode lookup) 5 - Le Naming récupère les "références" de l'objet serveur, crée l objet Stub et rend sa référence au client 8 - Le client effectue l'appel au serveur par appel à l objet Stub Cours "Systèmes et réseaux répartis" NFP 214 par Jacques LAFORGUE (jacques.laforgue@neuf.fr) version du 04/02/2010 slide numéro 22
23 Mise en œuvre RMI (5/5) Le client effectue l'appel au serveur par appel à l objet Stub rmiregistry 9105 NOM_OD Naming Naming Client Serveur 8 8 Stub Sekelton JVM Client JVM Serveur Cours "Systèmes et réseaux répartis" NFP 214 par Jacques LAFORGUE (jacques.laforgue@neuf.fr) version du 04/02/2010 slide numéro 23
24 Exemple RMI : Description Cet exemple correspond en la création d'un seul objet distribué, nommé HELLO, utilisé par deux clients en parallèle Il encapsule un objet métier, un Individu composé d'un nom et d'un prénom Deux approches fonctionnelles côté serveur : (cas A) l'objet distribué permet les services suivants : obtenir un texte de bienvenu correspondant à l'individu en question changer l'identité de la personne (cas B) l'objet distribué permet le get et set sur l'individu Deux approches fonctionnelles côté client : en correspondance avec le cas A : le client 1 demande le texte de bienvenu et l'affiche le client 2 change l'identité de l'individu en correspondance avec le cas B : le client 1 demande l'individu, construit le texte de bienvenu et l'affiche le client 2 change l'individu Cours "Systèmes et réseaux répartis" NFP 214 par Jacques LAFORGUE (jacques.laforgue@neuf.fr) version du 04/02/2010 slide numéro 24
25 Exemple RMI : Architecture (cas A) Le client 1 demande un service au serveur qui réalise le service demandé Le traitement se fait côté serveur On est dans un cas "orienté service" Les clients n'ont pas de copie des objets encapsulés Cours "Systèmes et réseaux répartis" NFP 214 par Jacques LAFORGUE (jacques.laforgue@neuf.fr) version du 04/02/2010 slide numéro 25
26 Exemple RMI : Architecture (cas B) Le client 1 demande le contenu de l'objet et en reçoit une copie Le traitement se fait côté client On est dans un cas "orienté objet" Les clients récupèrent une copie de l'objet encapsulé par le serveur Cours "Systèmes et réseaux répartis" NFP 214 par Jacques LAFORGUE (jacques.laforgue@neuf.fr) version du 04/02/2010 slide numéro 26
27 Exemple RMI : Commentaires (1/2) Le code est disponible sur le site (réf: NFP214_Exemple_009_ExempleRMI) Le serveur : deux scripts pour l'exécuter : runserveur.bat : l'adaptateur doit être exécuter avant runserveuretregistre.bat : l'adaptateur est exécuter par le serveur. le programme principal : ExempleRmi.java crée et exécute l'adaptateur en fonction d'un paramètre crée l'objet distribué comme un objet quelconque enregistre l'od dans l'adaptateur se trouvant au port 9999 l'objet distribué : HelloOD.java hérite de UnicatRemoteObject implémente les méthodes distantes de l'interface HelloODInt encapsule un objet Individu l'objet Individu objet quelconque implémente Serializable pour pouvoir être échangé (cas B) entre le serveur et le client (inutile dans le cas A) Cours "Systèmes et réseaux répartis" NFP 214 par Jacques LAFORGUE (jacques.laforgue@neuf.fr) version du 04/02/2010 slide numéro 27
28 Exemple RMI : Commentaires (2/2) Cas 1, Client 1 : lookup : connexion sur l'od appel à la méthode distante hello() qui retourne la phrase de bienvenue construite par l'od affiche sa valeur si cette dernière change sur le serveur Cas 1, Client 2 : lookup : connexion sur l'od appel à la méthode distante setident(nom,prenom) afin de changer les valeurs sur l'od Cas 2, Client 1 : lookup : connexion sur l'od appel à la méthode distante getindividu() qui retourne l'individu de l'od le client fabrique la phrase de bienvenue affiche la chaîne si l'individu sur le serveur à changé ATTENTION: il faut implémenter la méthode equals de la classe Individu Cas 2, Client 2 : lookup : connexion sur l'od appel à la méthode distante setindividu() pour changer l'individu. Cours "Systèmes et réseaux répartis" NFP 214 par Jacques LAFORGUE (jacques.laforgue@neuf.fr) version du 04/02/2010 slide numéro 28
29 Exemple RMI : Le programme principal (serveur) public class ExempleRMI public static void main(string args[]) throws Exception if (args.length == 1) if (args[0].equals("registre")) LocateRegistry.createRegistry(9999); System.out.println("Création de l'objet distribué"); HelloOD od = new HelloOD("Pierre","DUPONT"); System.out.println("Enregistrement de l'objet distribué"); Naming.rebind("rmi://localhost:9999/HELLO",od); System.out.println("Bus en ecoute..."); DataInputStream in = new DataInputStream(System.in); System.out.print("Taper rc, pour arreter le serveur..."); System.out.flush(); String valeur= in.readline(); Naming.unbind("rmi://localhost:9999/HELLO"); UnicastRemoteObject.unexportObject(od,true /*forcer*/); Indispensable pour finir la JVM Cours "Systèmes et réseaux répartis" NFP 214 par Jacques LAFORGUE (jacques.laforgue@neuf.fr) version du 04/02/2010 slide numéro 29
30 Exemple RMI : L'OD public class HelloOD extends UnicastRemoteObject implements HelloODInt private Individu individu; public HelloOD(String nom,string prenom) throws RemoteException super(); individu = new Individu(nom,prenom); public String hello() return("hello " + individu.getnom() + " " + individu.getprenom()); synchronized public void setident(string nom,string prenom) individu.setnom(nom); individu.setprenom(prenom); public Individu getindividu() return(individu); public void setindividu(individu a_individu) individu = a_individu; Cours "Systèmes et réseaux répartis" NFP 214 par Jacques LAFORGUE (jacques.laforgue@neuf.fr) version du 04/02/2010 slide numéro 30
31 Exemple RMI : L'interface de l'od public interface HelloODInt extends Remote // POUR LE CAS A // ============= public String hello() throws RemoteException; public void setident(string nom,string prenom) throws RemoteException; // POUR LE CAS B // ============= public Individu getindividu() throws RemoteException; public void setindividu(individu a_individu) throws RemoteException; Cours "Systèmes et réseaux répartis" NFP 214 par Jacques LAFORGUE (jacques.laforgue@neuf.fr) version du 04/02/2010 slide numéro 31
32 Exemple RMI : L'objet public class Individu implements Serializable String nom; String prenom; public Individu(String a_nom,string a_prenom) nom = a_nom; prenom = a_prenom; public String getnom()return(nom); public String getprenom()return(prenom); public void setnom(string a_nom)nom=a_nom; public void setprenom(string a_prenom)prenom=a_prenom; public boolean equals(object a_object) if (a_object == null) return false; Individu l_ind = (Individu)a_object; return( l_ind.nom.equals(this.nom) && l_ind.prenom.equals(this.prenom) ); Cours "Systèmes et réseaux répartis" NFP 214 par Jacques LAFORGUE (jacques.laforgue@neuf.fr) version du 04/02/2010 slide numéro 32
33 Exemple RMI : Les clients du cas A public class CasA_Client1 public static void main(string args[]) throws Exception HelloODInt helloservices = (HelloODInt)(Naming.lookup("rmi://localhost:9999/HELLO")); String messageold = ""; String message = helloservices.hello(); while(true) if (message.equals(messageold)==false) System.out.println(message); messageold = message; message = helloservices.hello(); public class CasA_Client2 public static void main(string args[]) throws Exception HelloODInt helloservices = (HelloODInt)(Naming.lookup("rmi://localhost:9999/HELLO")); helloservices.setident(args[0],args[1]); Cours "Systèmes et réseaux répartis" NFP 214 par Jacques LAFORGUE (jacques.laforgue@neuf.fr) version du 04/02/2010 slide numéro 33
34 Exemple RMI : Les clients du cas B public class CasB_Client1 public static void main(string args[]) throws Exception HelloODInt helloobjet = (HelloODInt)(Naming.lookup("rmi://localhost:9999/HELLO")); Individu l_individu = helloobjet.getindividu(); Individu l_individuold = null; while(true) if (l_individu.equals(l_individuold)==false) String message = "BONJOUR : " + l_individu.getnom() + l_individu.getprenom(); System.out.println(message); l_individuold = l_individu; l_individu = helloobjet.getindividu(); public class CasB_Client2 public static void main(string args[]) throws Exception HelloODInt helloobjet = (HelloODInt)(Naming.lookup("rmi://localhost:9999/HELLO")); Individu l_individu = new Individu(args[0],args[1]); helloobjet.setindividu(l_individu); Cours "Systèmes et réseaux répartis" NFP 214 par Jacques LAFORGUE (jacques.laforgue@neuf.fr) version du 04/02/2010 slide numéro 34
35 Exemple RMI : La variante avec exportobject On utilise exportobject quand la classe de l'od n'hérite pas de UnicastRemoteObject La classe de l'od implémente toujours l'interface (voir sur le site l'exemple NFP214_Exemple_009_ExempleRMI_exportObject HelloOD od = new HelloOD("Pierre","DUPONT"); // HelloOD n'hérite pas de UnicastRemoteObject UnicastRemoteObject.exportObject(od); Naming.rebind("rmi://localhost:9999/HELLO",od) ; Cours "Systèmes et réseaux répartis" NFP 214 par Jacques LAFORGUE (jacques.laforgue@neuf.fr) version du 04/02/2010 slide numéro 35
36 L'atelier 6 : La conversion d'une devise Cet atelier contient 6 cas graduels de mise en œuvre d'une application distribué en RMI L'objectif de cet atelier est de montrer 3 cas de mise en œuvre et leurs avantages et désavantages Tous ces cas se compilent en utilisant: compil.bat Pour l'exécution : runorb.dat runserveur.bat runclient.bat (dans une 1ère fenêtre) (dans une 2ème fenêtre) (dans une 3ème fenêtre) Cours "Systèmes et réseaux répartis" NFP 214 par Jacques LAFORGUE (jacques.laforgue@neuf.fr) version du 04/02/2010 slide numéro 36
37 L'atelier 6 : cas 1 (2/2) Prenons un cas fonctionnel: la conversion d'une devise. Une devise est définit par 2 noms de monnaies et le taux permettant de passer de la première à la deuxième. La devise est donc une classe Devise.java. Le service du serveur est de retourner au client un objet devise avec lequel il peut faire ses conversions. Cet objet devise est créé dans l'interface et n'est pas connu du serveur. Cette solution est correcte. Le client ne peut pas changer le taux (private). L'objet devise est protégé. Mais on peut y voir un désavantage: si le serveur veut changer le taux d'une devise, il ne le peut pas. L'objet devise géré par le client est une copie de celui créé par le serveur. Cours "Systèmes et réseaux répartis" NFP 214 par Jacques LAFORGUE (jacques.laforgue@neuf.fr) version du 04/02/2010 slide numéro 37
38 L'atelier 6 : cas 1 (1/2) Méthodes distantes convertir1() convertir2() Client1 getdevise(nom) new Devise( ) Serveur ServeurPP Cours "Systèmes et réseaux répartis" NFP 214 par Jacques LAFORGUE (jacques.laforgue@neuf.fr) version du 04/02/2010 slide numéro 38
39 L'atelier 6 : cas 2 Dans ce cas, le serveur encapsule les 2 devises afin de pouvoir changer leur taux à tout moment. Le programme ServeurPP.java permet d'intervenir sur le serveur afin de changer un des taux des devises. Une fois le client lancé on s'aperçoit que même si on change le taux côté serveur, il n'est pas impacté. Il conserve le taux initial car l'objet Devise appartient à l'espace mémoire du client. Le client peut changer le taux si l'attribut est accessible (public ou setteur). Cours "Systèmes et réseaux répartis" NFP 214 par Jacques LAFORGUE (jacques.laforgue@neuf.fr) version du 04/02/2010 slide numéro 39
40 L'atelier 6 : cas 3 Ce cas permet de montrer comment on peut pallier au désavantage énoncé précédemment. Le client ne récupère plus des objets Devise mais il réalise autant de connexion que de serveur. Le programme ServeurPP crée autant de Serveur qu'il existe de devise à gérer Cours "Systèmes et réseaux répartis" NFP 214 par Jacques LAFORGUE (jacques.laforgue@neuf.fr) version du 04/02/2010 slide numéro 40
41 L'atelier 6 : cas 4 Si on analyse la cas précédent, on s'aperçoit que la notion de "Serveur" correspond à une Devise qui ferait des exportations de services RMI. Les classes Serveur.java et ServeurInt.java disparaissent et sont remplacées par les classes Devise.java et DeviseInt.java. On appelle une instance de la classe Devise un Objet Distribué. convertir1() convertir2() Devise1 settaux changer le taux convertir1() convertir2() Devise2 settaux Client1 ServeurPP Cours "Systèmes et réseaux répartis" NFP 214 par Jacques LAFORGUE (jacques.laforgue@neuf.fr) version du 04/02/2010 slide numéro 41
42 L'atelier 6 : cas 5 Un désavantage du cas précédent est que le client doit savoir à priori quelles devises le serveur gère. Dans le cas 5, le client se connecte au serveur de devise qui gère les devises et qui permet de signaler au client quelles devises il gère : la classe Serveur : gère les devises la classe Devise : gère 1 devise convertir1() convertir2() Devise1 settaux changer le taux convertir1() convertir2() Devise2 settaux getnomdevises() Serveur Client1 ServeurPP Cours "Systèmes et réseaux répartis" NFP 214 par Jacques LAFORGUE (jacques.laforgue@neuf.fr) version du 04/02/2010 slide numéro 42
43 L'atelier 6 : Cas 6 Le même cas précédant mais en utilisant la notion de package et de répertoire bin de génération. Cours "Systèmes et réseaux répartis" NFP 214 par Jacques LAFORGUE (jacques.laforgue@neuf.fr) version du 04/02/2010 slide numéro 43
44 Les autres ateliers sur RMI L'atelier 10 : Visualisation de l'adaptateur L'atelier 11 : La redondance de serveur (refondu par rapport à celui de l'année dernière) L'atelier 12 : Le calcul réparti L'atelier 13 : La référence d'od et factory en RMI (nouveau) Cours "Systèmes et réseaux répartis" NFP 214 par Jacques LAFORGUE (jacques.laforgue@neuf.fr) version du 04/02/2010 slide numéro 44
Remote Method Invocation (RMI)
Remote Method Invocation (RMI) TP Réseau Université Paul Sabatier Master Informatique 1 ère Année Année 2006/2007 Plan Objectifs et Inconvénients de RMI Fonctionnement Définitions Architecture et principe
Plus en détailRMI le langage Java XII-1 JMF
Remote Method Invocation (RMI) XII-1 Introduction RMI est un ensemble de classes permettant de manipuler des objets sur des machines distantes (objets distants) de manière similaire aux objets sur la machine
Plus en détailRMI. Remote Method Invocation: permet d'invoquer des méthodes d'objets distants.
RMI Remote Method Invocation: permet d'invoquer des méthodes d'objets distants. Méthode proche de RPC. Outils et classes qui rendent l'implantation d'appels de méthodes d'objets distants aussi simples
Plus en détailJava RMI. Arnaud Labourel Courriel: arnaud.labourel@lif.univ-mrs.fr. Université de Provence. 8 mars 2011
Java RMI Arnaud Labourel Courriel: arnaud.labourel@lif.univ-mrs.fr Université de Provence 8 mars 2011 Arnaud Labourel (Université de Provence) Java RMI 8 mars 2011 1 / 58 Web services Services par le réseau
Plus en détailRemote Method Invocation en Java (RMI)
Remote Method Invocation en Java (RMI) Modélisation et construction des applications réparties (Module M-4102C) J. Christian Attiogbé Fevrier 2015 J. Christian Attiogbé (Fevrier 2015) Remote Method Invocation
Plus en détailCalcul Parallèle. Cours 5 - JAVA RMI
Calcul Parallèle Cours 5 - JAVA RMI Eric Goubault Commissariat à l Energie Atomique & Chaire Ecole Polytechnique/Thalès Saclay Le 28 février 2012 Eric Goubault 1 28 février 2012 Remote Method Invocation
Plus en détailRemote Method Invocation Les classes implémentant Serializable
Parallélisme Architecture Eric Goubault Commissariat à l Energie Atomique Saclay Classe qui implémente la méthode distante (serveur): - dont les méthodes renvoient un objet serializable - ou plus généralement
Plus en détailProgrammation répartie RPC & RMI
Programmation répartie RPC & RMI Plan du cours Introduction Définitions Problématiques Architectures de distribution Distribution intra-applications Notion de processus Programmation multi-thread Distribution
Plus en détailConception de serveurs d'applications ouverts
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
Plus en détailDis papa, c est quoi un bus logiciel réparti?
Dis papa, c est quoi un bus logiciel réparti? Raphael.Marvie@lifl.fr LIFL IRCICA Equipe GOAL Octobre 2006 10. Des sockets aux bus logiciels répartis 1 0. Une application répartie 2 Objectif Découvrir la
Plus en détailJava Naming and Directory Interface
Introduction Java Naming and Directory Interface Gaël Thomas gael.thomas@lip6.fr Université Pierre et Marie Curie Master Informatique M2 Spécialité SAR Java Naming and Directory Interface (JNDI) Java Standard
Plus en détailTP1 : Initiation à Java et Eclipse
TP1 : Initiation à Java et Eclipse 1 TP1 : Initiation à Java et Eclipse Systèmes d Exploitation Avancés I. Objectifs du TP Ce TP est une introduction au langage Java. Il vous permettra de comprendre les
Plus en détailChapitre 10. Les interfaces Comparable et Comparator 1
Chapitre 10: Les interfaces Comparable et Comparator 1/5 Chapitre 10 Les interfaces Comparable et Comparator 1 1 Ce chapitre a été extrait du document "Objets, Algorithmes, Patterns" de [René Lalement],
Plus en détailIntergiciel - concepts de base
Intergiciel - concepts de base Ada Diaconescu, Laurent Pautet & Bertrand Dupouy ada.diaconescu _at_ telecom-paristech.fr Rappel : système réparti Système constitué de multiples ressources informatiques
Plus en détailCorrigé des exercices sur les références
Corrigé des exercices sur les références Exercice 3.1.1 dessin Pour cet exercice, vous allez dessiner des structures de données au moyen de petits schémas analogues à ceux du cours, comportant la pile
Plus en détailGénéralités. javadoc. Format des commentaires. Format des commentaires. Caractères spéciaux. Insérer du code
Généralités javadoc Université de Nice - Sophia Antipolis Richard Grin Version 1.4.1 8/2/11 javadoc produit de la documentation en partant de commentaires particuliers insérés dans le code source des classes
Plus en détailProgrammation réseau avec Java. 3/7 RMI, un peu de sécurité et CORBA
Programmation réseau avec Java 3/7 RMI, un peu de sécurité et CORBA Olivier Ricou 5 juin 2008 Java, comme CORBA avant, permet d exécuter des taches à distances avec la RMI. Cette partie aborde les points
Plus en détail[APPLICATON REPARTIE DE VENTE AUX ENCHERES]
2012 Polytech Nice- Sophia El Hajji Khalil Yousfi Hichem SI4 - Log [APPLICATON REPARTIE DE VENTE AUX ENCHERES] Sommaire Architecture de l application... 3 Le Serveur... 3 Le Client... 4 Passage en CORBA...
Plus en détailJava - RMI Remote Method Invocation. Java - RMI
Remote Method Invocation Yann Viémont Université de Versailles St-Quentin Plan 1. Introduction 2. Rappels sur les RPC 3. Le modèle objet de Java-RMI 4. Architecture générale 1. Introduction = Disponible
Plus en détailPackage Java.util Classe générique
Package Java.util Classe générique 1 Classe Vector La taille est dynamique: dès qu un tableau vectoriel est plein, sa taille est doublée, triplée, etc. automatiquement Les cases sont de type Object add(object
Plus en détailAuto-évaluation Programmation en Java
Auto-évaluation Programmation en Java Document: f0883test.fm 22/01/2013 ABIS Training & Consulting P.O. Box 220 B-3000 Leuven Belgium TRAINING & CONSULTING INTRODUCTION AUTO-ÉVALUATION PROGRAMMATION EN
Plus en détailPour signifier qu'une classe fille hérite d'une classe mère, on utilise le mot clé extends class fille extends mère
L'héritage et le polymorphisme en Java Pour signifier qu'une classe fille hérite d'une classe mère, on utilise le mot clé extends class fille extends mère En java, toutes les classes sont dérivée de la
Plus en détailComposants Logiciels. Le modèle de composant de CORBA. Plan
Composants Logiciels Christian Pérez Le modèle de composant de CORBA Année 2010-11 1 Plan Un rapide tour d horizon de CORBA 2 Introduction au modèle de composant de CORBA Définition de composants CORBA
Plus en détailRAPPELS SUR LES METHODES HERITEES DE LA CLASSE RACINE Object ET LEUR SPECIALISATION (i.e. REDEFINITION)
CLASSE RACINE Object ancêtre de toutes les classes RAPPELS SUR LES METHODES HERITEES DE LA CLASSE RACINE Object ET LEUR SPECIALISATION (i.e. REDEFINITION) définit donc des méthodes héritées par toutes
Plus en détailTP n 2 Concepts de la programmation Objets Master 1 mention IL, semestre 2 Le type Abstrait Pile
TP n 2 Concepts de la programmation Objets Master 1 mention IL, semestre 2 Le type Abstrait Pile Dans ce TP, vous apprendrez à définir le type abstrait Pile, à le programmer en Java à l aide d une interface
Plus en détailThreads. Threads. USTL http://www.lifl.fr/ routier 1
Threads USTL http://www.lifl.fr/ routier 1 Rappels - Définitions un Process est un programme qui tourne et dispose de ses propres ressources mémoire. OS multi-tâche plusieurs process en concurrence un
Plus en détailINITIATION AU LANGAGE JAVA
INITIATION AU LANGAGE JAVA I. Présentation 1.1 Historique : Au début des années 90, Sun travaillait sur un projet visant à concevoir des logiciels simples et performants exécutés dans des PDA (Personnal
Plus en détailJava Licence Professionnelle 2009-2010. Cours 7 : Classes et méthodes abstraites
Java Licence Professionnelle 2009-2010 Cours 7 : Classes et méthodes abstraites 1 Java Classes et méthodes abstraites - Le mécanisme des classes abstraites permet de définir des comportements (méthodes)
Plus en détailIntroduction à Java. Matthieu Herrb CNRS-LAAS. Mars 2014. http://homepages.laas.fr/matthieu/cours/java/java.pdf
Introduction à Java Matthieu Herrb CNRS-LAAS http://homepages.laas.fr/matthieu/cours/java/java.pdf Mars 2014 Plan 1 Concepts 2 Éléments du langage 3 Classes et objets 4 Packages 2/28 Histoire et motivations
Plus en détailModèle client-serveur Plan. Modèle client-serveur. Modèle client-serveur définition. Modèle client-serveur communication par messages.
Modèle client- Modèle client- Plan Michel RIVEILL riveill@unice.fr Polytech Nice - Sophia Principe Traitement des défaillances Désignation, localisation et liaison Intégration aux langages de programmation
Plus en détailPrincipes. 2A-SI 3 Prog. réseau et systèmes distribués 3. 3 Programmation en CORBA. Programmation en Corba. Stéphane Vialle
2A-SI 3 Prog. réseau et systèmes distribués 3. 3 Programmation en CORBA Stéphane Vialle Stephane.Vialle@supelec.fr http://www.metz.supelec.fr/~vialle 1 Principes 2 Architecture 3 4 Aperçu d utilisation
Plus en détailQuelques patterns pour la persistance des objets avec DAO DAO. Principe de base. Utilité des DTOs. Le modèle de conception DTO (Data Transfer Object)
Quelques patterns pour la persistance des objets avec DAO Ce cours présente des modèles de conception utilisés pour effectuer la persistance des objets Université de Nice Sophia-Antipolis Version 1.4 30/8/07
Plus en détailEnvironnements de développement (intégrés)
Environnements de développement (intégrés) Tests unitaires, outils de couverture de code Patrick Labatut labatut@di.ens.fr http://www.di.ens.fr/~labatut/ Département d informatique École normale supérieure
Plus en détailJava DataBaseConnectivity
Java DataBaseConnectivity JDBC JDBC est une API Java (ensemble de classes et d interfaces défini par SUN et les acteurs du domaine des SGBD) permettant d accéder aux bases de données à l aide du langage
Plus en détailProgrammer en JAVA. par Tama (tama@via.ecp.fr( tama@via.ecp.fr)
Programmer en JAVA par Tama (tama@via.ecp.fr( tama@via.ecp.fr) Plan 1. Présentation de Java 2. Les bases du langage 3. Concepts avancés 4. Documentation 5. Index des mots-clés 6. Les erreurs fréquentes
Plus en détailLMI 2. Programmation Orientée Objet POO - Cours 9. Said Jabbour. jabbour@cril.univ-artois.fr www.cril.univ-artois.fr/~jabbour
LMI 2 Programmation Orientée Objet POO - Cours 9 Said Jabbour jabbour@cril.univ-artois.fr www.cril.univ-artois.fr/~jabbour CRIL UMR CNRS 8188 Faculté des Sciences - Univ. Artois Février 2011 Les collections
Plus en détailINTRODUCTION A JAVA. Fichier en langage machine Exécutable
INTRODUCTION A JAVA JAVA est un langage orienté-objet pur. Il ressemble beaucoup à C++ au niveau de la syntaxe. En revanche, ces deux langages sont très différents dans leur structure (organisation du
Plus en détailProgrammation Réseau. Sécurité Java. Jean-Baptiste.Yunes@univ-paris-diderot.fr. UFR Informatique 2012-2013. jeudi 4 avril 13
Programmation Réseau Sécurité Java Jean-Baptiste.Yunes@univ-paris-diderot.fr UFR Informatique 2012-2013 Java Sécurité? différentes sécurités disponibles et contrôlables intégrité contrôle d accès signature/authentification/cryptographie
Plus en détailas Architecture des Systèmes d Information
Plan Plan Programmation - Introduction - Nicolas Malandain March 14, 2005 Introduction à Java 1 Introduction Présentation Caractéristiques Le langage Java 2 Types et Variables Types simples Types complexes
Plus en détailCORBA. (Common Request Broker Architecture)
CORBA (Common Request Broker Architecture) Projet MIAGe Toulouse Groupe 2 1 CORBA, introduction (1/4) Les systèmes répartis permettent de créer des applications basées sur des composants auto-gérables,
Plus en détailSupervision et infrastructure - Accès aux applications JAVA. Document FAQ. Page: 1 / 9 Dernière mise à jour: 15/04/12 16:14
Document FAQ Supervision et infrastructure - Accès aux EXP Page: 1 / 9 Table des matières Introduction... 3 Démarrage de la console JMX...4 I.Généralités... 4 II.WebLogic... 5 III.WebSphere... 6 IV.JBoss...
Plus en détailUne introduction à Java
Une introduction à Java IFT 287 (Semaine 1) UNIVERSITÉ DE SHERBROOKE 1 Java - Historique Développé par Sun Microsystems en 1994 Inventeur James Gosling (canadien!) Objectif langage sûr (fortement typé)
Plus en détailStructure d un programme et Compilation Notions de classe et d objet Syntaxe
Cours1 Structure d un programme et Compilation Notions de classe et d objet Syntaxe POO 1 Programmation Orientée Objet Un ensemble d objet qui communiquent Pourquoi POO Conception abstraction sur les types
Plus en détailLangage Java. Classe de première SI
Langage Java Table des matières 1. Premiers pas...2 1.1. Introduction...2 1.2. Mon premier programme...2 1.3. Les commentaires...2 2. Les variables et les opérateurs...2 3. La classe Scanner...3 4. Les
Plus en détailCours intensif Java. 1er cours: de C à Java. Enrica DUCHI LIAFA, Paris 7. Septembre 2009. Enrica.Duchi@liafa.jussieu.fr
. Cours intensif Java 1er cours: de C à Java Septembre 2009 Enrica DUCHI LIAFA, Paris 7 Enrica.Duchi@liafa.jussieu.fr LANGAGES DE PROGRAMMATION Pour exécuter un algorithme sur un ordinateur il faut le
Plus en détailPage 1 sur 5 TP3. Thèmes du TP : l la classe Object. l Vector<T> l tutorial Interfaces. l Stack<T>
Page 1 sur 5 TP3 Lectures préalables : l Java_II l tutorial Interfaces Thèmes du TP : l la classe Object l Vector l Stack Une pile d'objects Les éléments de la classe Pile sont maintenant des instances
Plus en détailOpenPaaS Le réseau social d'entreprise
OpenPaaS Le réseau social d'entreprise Spécification des API datastore SP L2.3.1 Diffusion : Institut MinesTélécom, Télécom SudParis 1 / 12 1OpenPaaS DataBase API : ODBAPI...3 1.1Comparaison des concepts...3
Plus en détailACTIVITÉ DE PROGRAMMATION
ACTIVITÉ DE PROGRAMMATION The purpose of the Implementation Process is to realize a specified system element. ISO/IEC 12207 Sébastien Adam Une introduction 2 Introduction Ø Contenu Utilité de l ordinateur,
Plus en détailProjet gestion d'objets dupliqués
Projet gestion d'objets dupliqués Daniel Hagimont Daniel.Hagimont@enseeiht.fr 1 Projet Service de gestion d'objets dupliqués Mise en cohérence lors de la prise d'un verrou sur un objet Pas de verrous imbriqués
Plus en détail2 Chapitre 1 Introduction
1 Introduction Ce livre présente les Enterprise JavaBeans 2.0 et 1.1 qui constituent la troisième et la deuxième version de la spécification des Enterprise JavaBeans. Tout comme la plate-forme Java a révolutionné
Plus en détailPlan du cours. Historique du langage http://www.oracle.com/technetwork/java/index.html. Nouveautés de Java 7
Université Lumière Lyon 2 Faculté de Sciences Economiques et Gestion KHARKIV National University of Economic Introduction au Langage Java Master Informatique 1 ère année Julien Velcin http://mediamining.univ-lyon2.fr/velcin
Plus en détailInitiation à JAVA et à la programmation objet. raphael.bolze@ens-lyon.fr
Initiation à JAVA et à la programmation objet raphael.bolze@ens-lyon.fr O b j e c t i f s Découvrir un langage de programmation objet. Découvrir l'environnement java Découvrir les concepts de la programmation
Plus en détailPolymorphisme, la classe Object, les package et la visibilité en Java... 1
Polymorphisme, la classe Object, les package et la visibilité en Java. Polymorphisme, la classe Object, les package et la visibilité en Java.... 1 Polymorphisme.... 1 Le DownCast... 4 La Classe Object....
Plus en détailTD/TP PAC - Programmation n 3
Université Paris Sud Licence d informatique/iup-miage2 Année 2004-2005 Auteur : Frédéric Vernier Semaine : 11-16 octobre 2004 Conditions : sur machine avec les outils standards java web: http://vernier.frederic.free.fr/indexpac.html
Plus en détailCours 1: Java et les objets
Ressources Les interface homme-machine et le langage Java DUT première année Henri Garreta, Faculté des Sciences (Luminy) Cyril Pain-Barre & Sébastien Nedjar, IUT d Aix-Marseille (Aix) Cours 1: infodoc.iut.univ-aix.fr/~ihm/
Plus en détailProgrammation par les Objets en Java
Programmation par les Objets en Java Najib TOUNSI Les classes en Java (TD 3) I. Notion de classe I.1 Classe, champs, méthodes, instanciation, this, private vs. public. Créer une classe Point (coordonnée
Plus en détailCréation d objet imbriqué sous PowerShell.
Création d objet imbriqué sous PowerShell. Par Laurent Dardenne, le 13/01/2014. Niveau Ce tutoriel aborde la création d objet composé, c est-à-dire que certains de ses membres seront eux-mêmes des PSObjects.
Plus en détailExceptions. 1 Entrées/sorties. Objectif. Manipuler les exceptions ;
CNAM NFP121 TP 10 19/11/2013 (Séance 5) Objectif Manipuler les exceptions ; 1 Entrées/sorties Exercice 1 : Lire un entier à partir du clavier Ajouter une méthode readint(string message) dans la classe
Plus en détailServeur d'application Client HTML/JS. Apache Thrift Bootcamp
Serveur d'application Client HTML/JS Apache Thrift Bootcamp Pré-requis La liste ci-dessous de logiciels doit être installée et opérationnelle sur la machine des participants : Compilateur thrift http://thrift.apache.org/
Plus en détailTP3. Mail. Attention aux fausses manoeuvres lors de ce TP vous pouvez endommager votre mail sur ouindose.
Université Paris 7 M2 II Protocole Internet TP3 Mail Attention aux fausses manoeuvres lors de ce TP vous pouvez endommager votre mail sur ouindose. 1 Protocole SMTP 1. Le protocole SMTP est définit dans
Plus en détailIntergiciels pour la répartition CORBA : Common Object Request Broker. Patrice Torguet torguet@irit.fr Université Paul Sabatier
Intergiciels pour la répartition CORBA : Common Object Request Broker Patrice Torguet torguet@irit.fr Université Paul Sabatier Plan du cours 2 Introduction à CORBA Architecture de l ORB Implémentation
Plus en détailPremiers Pas en Programmation Objet : les Classes et les Objets
Chapitre 2 Premiers Pas en Programmation Objet : les Classes et les Objets Dans la première partie de ce cours, nous avons appris à manipuler des objets de type simple : entiers, doubles, caractères, booléens.
Plus en détailProjet de programmation (IK3) : TP n 1 Correction
Projet de programmation (IK3) : TP n 1 Correction Semaine du 20 septembre 2010 1 Entrées/sorties, types de bases et structures de contrôle Tests et types de bases Tests et types de bases (entiers) public
Plus en détailPrésentation de Java. Olivier de Pertat IT GROUP
Présentation de Java Olivier de Pertat IT GROUP Qu'est-ce que Java? Un langage de programmation orienté objets Une architecture de Virtual Machine Un ensemble d'api variées Un ensemble d'outils : le Java
Plus en détailGénéralités sur le Langage Java et éléments syntaxiques.
Généralités sur le Langage Java et éléments syntaxiques. Généralités sur le Langage Java et éléments syntaxiques....1 Introduction...1 Genéralité sur le langage Java....1 Syntaxe de base du Langage...
Plus en détailEncapsulation. L'encapsulation consiste à rendre les membres d'un objet plus ou moins visibles pour les autres objets.
Encapsulation L'encapsulation consiste à rendre les membres d'un objet plus ou moins visibles pour les autres objets. La visibilité dépend des membres : certains membres peuvent être visibles et d'autres
Plus en détailUtilisation de JAVA coté Application serveur couplé avec Oracle Forms Hafed Benteftifa www.degenio.com Novembre 2008
Introduction Utilisation de JAVA coté Application serveur couplé avec Oracle Forms Hafed Benteftifa www.degenio.com Novembre 2008 Forms 10g permet l utilisation du JAVA côté client et côté application
Plus en détailJADE : Java Agent DEvelopment framework. Laboratoire IBISC & Départ. GEII Université & IUT d Evry nadia.abchiche@ibisc.univ-evry.
: Java Agent DEvelopment framework Laboratoire IBISC & Départ. GEII Université & IUT d Evry nadia.abchiche@ibisc.univ-evry.fr Introduction à la plateforme JADE 1) Modèle d agent 2) Services 3) Norme FIPA
Plus en détailLambda! Rémi Forax Univ Paris-Est Marne-la-Vallée
Lambda! Rémi Forax Univ Paris-Est Marne-la-Vallée forax at univ-mlv dot fr - ParisJUG Java.next() - Mars 2012 What Else? Lambda == Inner class? Java a des lambdas depuis la version 1.1 Exemple utilisant
Plus en détailSynchro et Threads Java TM
Synchro et Threads Java TM NICOD JEAN-MARC Master 2 Informatique Université de Franche-Comté UFR des Sciences et Techniques septembre 2008 NICOD JEAN-MARC Synchro et Threads avec Java TM 1 / 32 Sommaire
Plus en détailProgramme Compte bancaire (code)
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; Programme Compte bancaire (code) namespace compte_bancaire /// Classe Program public
Plus en détailCréation d une application JEE
Création d une application JEE Rédacteurs : Alexandre Baillif, Philippe Lacomme, Raksmey Phan et Michaël PLAN Date : juillet 2010 Mise à jour : Michaël PLAN Date : octobre 2014 Avertissement : - ce document
Plus en détailTD Objets distribués n 3 : Windows XP et Visual Studio.NET. Introduction à.net Remoting
IUT Bordeaux 1 2005-2006 Département Informatique Licence Professionnelle ~ SI TD Objets distribués n 3 : Windows XP et Visual Studio.NET Introduction à.net Remoting Partie 1 : l'analyseur de performances
Plus en détailGEI 465 : Systèmes répartis
Université de Sherbrooke GEI 465 : Systèmes répartis Travaux à effectuer Ahmed Khoumsi Automne 2004 Page 1 Les deux premiers travaux que vous effectuerez vous donneront, respectivement, l occasion d utiliser
Plus en détailHéritage presque multiple en Java (1/2)
Héritage presque multiple en Java (1/2) Utiliser deux classes ou plus dans la définition d'une nouvelle classe peut se faire par composition. class Etudiant{ int numero; Diplome d; float passeexamen(examen
Plus en détailProgrammation Internet en Java
Chapitre 8 Programmation Internet en Java Vous avez déjà utilisé Internet, le plus connu des inter-réseaux mondiaux d ordinateurs et quelques-uns de ses services, en particulier le web et le courrier électronique.
Plus en détailProgrammation Par Objets
Programmation Par Objets Structures de données package java.util B. Carré Polytech Lille 1 Tableaux et structures de données Tableaux «Objets» taille fixe type des éléments : primitif (homogène) ou objets
Plus en détailPour plus de détails concernant le protocole TCP conférez vous à la présentation des protocoles Internet enseignée pendant.
Chapitre 7 Le mode de communication en connexion est, a priori, supporté par le protocole TCP. Ce protocole fournit une communication fiable; les données sont transmises comme chaînes d octets. Avant de
Plus en détailCette application développée en C# va récupérer un certain nombre d informations en ligne fournies par la ville de Paris :
Développement d un client REST, l application Vélib 1. Présentation L application présentée permet de visualiser les disponibilités des vélos et des emplacements de parking à la disposition des parisiens
Plus en détailProgrammation Objet Java Correction
INSA - 4 AE 2007 2008 Durée : 1H00 Contrôle Programmation Objet Java Correction Consignes Tous les documents sont autorisés, mais ils seront peu utiles. Indiquez vos nom et prénom sur chaque feuille. Le
Plus en détailObjets et Programmation. origine des langages orientés-objet
Objets et Programmation origine des langages orientés-objet modularité, encapsulation objets, classes, messages exemples en Java héritage, liaison dynamique G. Falquet, Th. Estier CUI Université de Genève
Plus en détailBases Java - Eclipse / Netbeans
Institut Galilée PDJ Année 2014-2015 Master 1 Environnements Java T.P. 1 Bases Java - Eclipse / Netbeans Il existe plusieurs environnements Java. Il est ESSENTIEL d utiliser la bonne version, et un environnement
Plus en détailAlfstore workflow framework Spécification technique
Alfstore workflow framework Spécification technique Version 0.91 (2012-08-03) www.alfstore.com Email: info@alfstore.com Alfstore workflow framework 2012-10-28 1/28 Historique des versions Version Date
Plus en détailLangage et Concepts de ProgrammationOrientée-Objet 1 / 40
Déroulement du cours Introduction Concepts Java Remarques Langage et Concepts de Programmation Orientée-Objet Gauthier Picard École Nationale Supérieure des Mines de Saint-Étienne gauthier.picard@emse.fr
Plus en détailInstitut Supérieur de Gestion. Cours pour 3 ème LFIG. Java Enterprise Edition Introduction Bayoudhi Chaouki
Institut Supérieur de Gestion Cours pour 3 ème LFIG Java Enterprise Edition Introduction Bayoudhi Chaouki 1 Java EE - Objectifs Faciliter le développement de nouvelles applications à base de composants
Plus en détailP 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 )
P r ob lé m a t iq u e d e la g é n é r icit é les versions de Java antérieures à 1.5 permettaient de créer des classes de structures contenant n'importe quels types d'objet : les collections (classes
Plus en détailServeur d'archivage 2007 Installation et utilisation de la BD exist
Type du document Procédure d'installation Auteur(s) Eric Bouladier Date de création 26/02/20007 Domaine de diffusion tous Validé par Equipe Versions Date Auteur(s) Modifications V1.00 26/02/2007 Eric Bouladier
Plus en détailDéveloppement, déploiement et sécurisation d'applications JEE
JBoss Développement, déploiement et sécurisation d'applications JEE Franck SIMON Résumé Ce livre sur JBoss s'adresse aux développeurs Java quotidiennement confrontés au développement et au déploiement
Plus en détailOS Réseaux et Programmation Système - C5
OS Réseaux et Programmation Système - C5 Rabie Ben Atitallah rabie.benatitallah@univ-valenciennes.fr RPC - XDR Rappel RPC: Remote Procedure Call Besoin d un environnement de haut niveau pour le développement
Plus en détailImplementing a simple RMI Application over the Internet (using and comparing HTTP tunneling, RMI Proxy)
Implementing a simple RMI Application over the Internet (using and comparing HTTP tunneling, RMI Proxy) Abstract Un problème se pose lorsque l on veut effectuer des appels RMI à travers un firewall, car
Plus en détailLangage et Concepts de Programmation Objet. 1 Attributs et Méthodes d instance ou de classe. Travaux Dirigés no2
Langage et Concepts de Programmation Objet Travaux Dirigés no2 Pôle Informatique École Nationale Supérieure des Mines de St-Etienne Vous trouverez plus de détails sur les concepts abordés lors de ce TD
Plus en détailJava Licence Professionnelle CISII, 2009-2010
Licence Professionnelle CISII, 2009-2010 Cours 1 : Introduction à Java A. Belaïd abelaid@loria.fr Cours disponible sur le site : http://www.loria.fr/~abelaid puis Teaching 1 Fonctionnement 12 séances :
Plus en détailGestion distribuée (par sockets) de banque en Java
Gestion distribuée (par sockets) de banque en Java Université Paris Sud Rappel sur la solution locale de gestion simple de banque L objet de cet exercice était de créer une application java qui implante
Plus en détailJava Licence Professionnelle CISII, 2009-10
Java Licence Professionnelle CISII, 2009-10 Cours 4 : Programmation structurée (c) http://www.loria.fr/~tabbone/cours.html 1 Principe - Les méthodes sont structurées en blocs par les structures de la programmation
Plus en détailChapitre VI- La validation de la composition.
Chapitre VI- La validation de la composition. Objectifs du chapitre : Expliquer les conséquences de l utilisation de règles de typage souples dans SEP. Présenter le mécanisme de validation des connexions
Plus en détailChapitre I Notions de base et outils de travail
Chapitre I Notions de base et outils de travail Objectifs Connaître les principes fondateurs et l historique du langage Java S informer des principales caractéristiques du langage Java Connaître l environnement
Plus en détailArchitecture Orientée Service, JSON et API REST
UPMC 3 février 2015 Précedemment, en LI328 Architecture générale du projet Programmation serveur Servlet/TOMCAT Aujourd hui Quelques mots sur les SOA API - REST Le format JSON API - REST et Servlet API
Plus en détailJava c est quoi? Java. Java. Java : Principe de fonctionnement 31/01/2012. 1 - Vue générale 2 - Mon premier programme 3 - Types de Programme Java
1 - Vue générale 2 - Mon premier programme 3 - Types de Programme 1 2 c est quoi? Technologie développée par SUN Microsystems lancée en 1995 Dans un des premiers papiers* sur le langage JAVA, SUN le décrit
Plus en détailExtension SSO Java. Cette note technique décrit la configuration et la mise en œuvre du filtre de custom SSO Java.
Note technique W4 Engine Extension SSO Java Cette note technique décrit la configuration et la mise en œuvre du filtre de custom SSO Java. 1 Présentation 3 2 Custom SSO Java 4 3 Bilan 10 Sommaire Référence
Plus en détailNFP111 Systèmes et Applications Réparties
NFP111 Systèmes et Applications Réparties 1 de 34 NFP111 Systèmes et Applications Réparties Cours 7 - CORBA/Partie 1 Claude Duvallet Université du Havre UFR Sciences et Techniques 25 rue Philippe Lebon
Plus en détail