Rapport de projet de fin d études

Dimension: px
Commencer à balayer dès la page:

Download "Rapport de projet de fin d études"

Transcription

1 TELECOM SUDPARIS VAP : ARCHITECTE DE SERVICES EN RESEAU Rapport de projet de fin d études Comparaison et évaluation de serveurs d'applications Java Sarafou BALDE Muqiu ZHENG Encadrante: Mme Sophie CHABRIDON Le 26 Janvier 2011

2 Sommaire I. Introduction... 3 II. Etude et mise en œuvre de la spécification des EJB Quelques éléments sur les EJB Quelles sont les évolutions apportées par les EJB La mise en œuvre des EJB : les serveurs d applications... 5 III. L application Mailbox Description de l'architecture de l'application Mailbox Mise en œuvre de la solution... 7 IV. Déploiement sous Glassfish... 9 V. Déploiement sous JonAS Le serveur Jonas Installation et configuration de JonAS Développement du Mailbox sous JonAS VI. Déploiement sous SPRING Introduction au Spring Framework Solutions proposées de déploiement VII. Comparaison de performances Glassfish VS Jonas Spring VS EJB VIII. Management de Projet IX. Bilan X. Références

3 I. Introduction Les serveurs d applications Java EE ont eu un grand succès ces dernières années notamment dans le monde professionnel. Ils occupent une place de choix dans les systèmes d information des entreprises. Ce succès est dû à plusieurs raisons : Le langage JAVA s est peu à peu imposé comme un langage robuste et facile à maintenir Les systèmes d informations devenant de plus en plus complexes, les communications inter-applications s accroissent, d où un fort besoin d intégration La centralisation de la «logique» métier facilite les mises à jour et garantit la même version applicative à tous les utilisateurs (pas de risque de vieilles versions de données ou de codes sources pouvant amener une incompatibilité entre les applications) Le découpage des applications en plusieurs «couches» permet d augmenter la sécurité. Ainsi les accès sont gérés de manière centrale et les clients n accèdent pas directement à la couche de données. Les serveurs d applications proposent également une bonne gestion de charge. En effet ils offrent une souplesse dans la répartition et la gestion des traitements avec notamment la possibilité de déployer les traitements dans un environnement distribué. Surfant sur cette vague plusieurs acteurs se sont lancés dans le développement de serveurs d applications Java EE. Les éditeurs absents sur ce créneau tentent aujourd hui de combler leur retard en orientant une partie de leur stratégie vers la proposition de solutions de cloud computing et de virtualisation. C est ainsi que nous avons assisté récemment à la transformation du marché des serveurs d'applications Java EE qui mettent en œuvre la spécification des EJB 3.0. Avec le rachat de SUN par Oracle, le serveur d applications Glassfish a ainsi changé de mains. Du coté de l Open source, il y a également des avancées avec la solution JonAS du consortium OW2 qui enrichit son offre en intégration et architecture orientée services. Les «concurrents» de la spécification des EJB3 ne sont pas en reste avec le rachat de SpringSource, fournisseur de la plate-forme Spring, par VMWare à l'été Notre projet de fin d études s inscrit dans ce cadre et a plusieurs objectifs, qui sont : Etudier la spécification des EJB 3.0 Prendre la main sur les serveurs d application Java EE Glassfish et Jonas ainsi que le Framework Spring 3

4 Spécifier une application de taille significative et la développer sur chacune des ces trois plates formes Faire une comparaison qualitative et quantitative entre les trois plates formes (Glassfish, Jonas et Spring) II. Etude et mise en œuvre de la spécification des EJB 3.0 Dans cette partie nous présentons les plus importantes évolutions de la spécification des EJB (2.0 vers 3.0). Avant d aborder ces évolutions, nous allons répondre à la question : C est quoi un EJB? 1. Quelques éléments sur les EJB La technique Enterprise JavaBeans (EJB) est une architecture de composants logiciels côté serveur pour la plateforme de développement Java EE. Cette architecture propose un cadre pour créer des composants distribués (c est-à-dire déployés sur des serveurs distants) écrit en langage de programmation Java et hébergés au sein d'un serveur applicatif permettant de représenter des données (EJB dit entité), de proposer des services avec ou sans conservation d'état entre les appels (EJB dit session), ou encore d'accomplir des tâches de manière asynchrone (EJB dit message). Tous les EJB peuvent évoluer dans un contexte transactionnel 1. Les EJB permettent aux développeurs d éviter à se préoccuper de tout ce qui a trait au système (transactions, sécurité, persistance, ). Pour être déployés, les EJB ont besoin d un conteneur qui est souvent intégré dans les serveurs d applications. Les EJB représentent une brique maîtresse de la plate-forme Java EE. Figure 1 - Architecture 3 tiers 1 4

5 2. Quelles sont les évolutions apportées par les EJB 3.0 La version 3.0 de la spécification des EJB ont apporté une révolution dans la manière de développer des applications Java EE par rapport aux versions précédentes. Nous allons citer quelques unes parmi les plus importantes. a) La gestion des EJB de type Session Les EJB de type Session, conçus pour encapsuler le logique métier, constituent l un des deux types d EJB. La gestion des EJB de type Session (Stateless et Stateful) se faisait au travers de fichiers XML, grâce à l apparition des annotations dans Java EE 5, cette gestion se fait de manière très simple (utilisation des b) La persistance L une des critiques les plus virulentes sur les EJB 1 et EJB 2 est la complexité de la gestion de la persistance. La persistance consiste à associer un objet à un modèle relationnel dans une base de données 2. Les EJB 3 ont apporté une solution à ce problème avec la spécification JPA (Java Persistance API) qui remplace avantageusement CMP (Container Managed Persistence) qui était la solution sous EJB 2.0. Cette API a plusieurs implémentations dont la plus connue est Hibernate. L permet de spécifier qu une classe doit être persistée par JPA. 3. La mise en œuvre des EJB : les serveurs d applications Nous avons vu que pour fonctionner, les EJB ont besoin d'un conteneur qui est généralement intégré dans un serveur d'applications. La figure 2 montre l'architecture d'un serveur d'application. Le serveur d'applications est un logiciel d'infrastructure offrant un contexte d'exécution pour des composants applicatifs 3. Ils implémentent: la logique métier de l'application grâce aux EJB Une couche de persistance (JPA,...) Un moteur de servlets des composants de connexions et de communication (JNDI, JDBC, JMS, Java RMI, Java IDL...)

6 Figure 2 Serveur d'applications III. L application Mailbox L'un des objectifs du projet est de développer une application de taille significative sur trois plateformes. L'application que nous avons développé un gestionnaire de mail (Mailbox manager). Cette application doit pouvoir gérer des boites mails et proposer une interface de gestion des différents utilisateurs. Les utilisateurs doivent pouvoir envoyer des messages, lire des messages, effacer des messages, etc. L'administrateur du Mailbox doit pouvoir ajouter un utilisateur, modifier les droits d'un utilisateur (lecture, écriture de messages ou de news). L'application Mailbox manager doit en outre être multi-tiers. 1. Description de l'architecture de l'application Mailbox Pour réaliser l'architecture proposée dans le sujet (voir figure 3), nous avons développé l'application en utilisant la technologie Java EE. 6

7 Figure 3 - Architecture proposée L'application est constituée de 3 "couches" (3-tiers): - Une couche client ou couche présentation constituée par une interface client et une interface administrateur. Cette couche permet d'interagir avec l'application et met à disposition des utilisateurs un certain nombre d'opérations. - Une couche "traitement des données" qui correspond à la mise en œuvre de l'ensemble des règles métiers de l'application. - Une couche "données" qui permet le stockage persistant des données. Pour stocker les données, nous avons utilisé une base de données MySQL fournie par l école. 2. Mise en œuvre de la solution Dans cette partie, nous allons décrire la solution nous avons mis en œuvre dans le projet. c) Les clients Pour accéder aux différentes fonctions du Mailbox manager, l'application propose deux interfaces: une interface utilisateur et une interface administrateur. L'interface utilisateur: Cette interface est obtenue en lançant le client utilisateur (MailBoxClient). Elle est accessible après une authentification de l'utilisateur (login et mot de passe) et permet la gestion des messages à travers les opérations telles que: - Envoyer un message - Lire un message 7

8 - Envoyer une news - Afficher les messages non lus - Supprimer un message - etc.. L'interface administrateur On y accède en lançant le client administrateur (AdministratorClient). Pour simplifier la gestion, ce client ne nécessite pas d'authentification. Cette interface permet de gérer les utilisateurs du MailBox. L'administrateur peut notamment: - Ajouter un utilisateur - Modifier les droits d'un utilisateur (lecture, écriture message ou lecture, écriture news...) - Supprimer un utilisateur - etc. d) Les composants coté serveur Coté serveur, nous avons deux classes (MailBoxManagerBean et DirectoryManagerBean) implémentant les interfaces (MailBoxManager et DirectoryManager). Ces deux classes implémentent l'ensemble des fonctionnalités offertes par l'application, elles mettent donc en œuvre les opérations mises en visibilité aux utilisateurs et aux administrateurs. e) Le stockage des données Pour la persistance des données, nous avons mis en place deux classes pour décrire les tables dans la base de données à distance. User: qui contient les informations de l'utilisateur (login, mot de passe, droits...) et les fonctions de traitement de ces données. L indique que un utilisateur sera relié aux plusieurs messages. Message: qui est la classe qui traite deux type de message : mail et news. Il contient notamment les données des messages : sujet, corps du message, type du message, date du message, envoyeur, receveur, variable pour savoir si le message a été lu, etc. Ci-dessous (Figure 4) un aperçu de la base de données créée lors du déploiement, les clés primaires des tables sont générées automatiquement. Figure 4 - Aperçu de la table 8

9 IV. Déploiement sous Glassfish Nous avons commencé notre développement sous Glassfish. GlassFish est le nom du serveur d'applications Open Source Java EE 5 et désormais Java EE 6 avec la version. Dans cette partie, nous allons décrire comment déployer ce programme sous Glassfish. f) Installation et configuration du Glassfish 1 Télécharger GlassFish en utilisant le lien: https://download.java.net/glassfish/3.0.1/release/glassfish zip 2 Extraire le fichier zip. 3 Configurer les variables d environnement comme $GLASSFISH_HOME et $CLASSPATH pour faciliter le travail sous Glassfish. 4 Lancer le Glassfish avec la commande : asadmin start-domain domain1, puis rendezvous sur le lien S il fonctionne bien, la page suivante doit être affichée. Figure 5 - Serveur Galassfish sur localhost 5 Configurer la source de base de données du Glassfish sur le lien : Créer un «JDBC connection pool» en donnant le nom de base de donnée, le URL, le nom du serveur, l utilisateur et le mot de passe. Et puis créer une nouvelle JDBC ressource en utilisant ce pool. 9

10 Figure 6 - page de configuration de la base g) Déploiement de l application Cette version de Glassfish nous permet de beaucoup simplifier la procédure de déploiement des applications. On n a plus besoin d autre descripteur comme ejb-jar.xml, qui est nécessaire pour la version précédente. L arborescence du projet est comme suivant : src : qui contient tous les source Java donc il y a trois paquets. META-INF : qui contient un descripteur persistence.xml. Ce fichier contient la configuration de base pour le mapping notamment en fournissant les informations sur la connexion à la base de données à utiliser. 10

11 client / ejb / entity : qui ont été créés par le compilateur ou on met les classes. build.xml : qui le descripteur de l outil de construction Ant. Il nous permet de compiler, deployer et exécuter l application. V. Déploiement sous JonAS Dans cette partie, nous traitons du développement de l application Mailbox sou Jonas. 1. Le serveur Jonas JonAs (Java Open Application Server) est un projet Open Source développé au sein du consortium OW2 (INRIA, BULL, France Telecom). JOnAS est certifié Java EE 5 depuis La version que nous avons utilisée dans notre projet est la a) Basé sur OSGi La nouvelle architecture JOnAS 5 s'appuie sur un modèle de composants OSGi. Figure 7 - Architecture JonAS basé sur OSGi

12 JOnAS est un ensemble de bundles OSGi, les services techniques sont des services OSGi. Dans cette nouvelle architecture, il est facile de remplacer ou d implémenter un service. Les services peuvent être démarrés, arrêtés ou reconfiguré alors que le serveur est en exécution. b) JonAS 5 intègre un conteneur pour les EJB 3.0 JOnAS fournit toutes les ressources nécessaires pour mettre en œuvre les EJB 3.0 (et pour Java EE 5 en général). Il inclut: Un conteneur EJB 3 (Easybeans, développé au sein du consortium OW2 ) Un conteneur Web (Tomcat ou Jetty) Plusieurs protocoles RMI (IIOP, JRMP, Irmi) sont également supportés Une implémentation Open source de JMS (JORAM 5) c) Gestion du serveur JonAS embarque une console Web pour la configuration du serveur, le déploiement d applications, etc. Figure 8 - Console d'administration de JonAS 3. Installation et configuration de JonAS Une fois que le serveur d application JonAS est téléchargé 5, un certain nombre de variables doivent être configurés (JONAS_ROOT et JONAS_ROOT /bin doivent être mises dans le PATH). Structure du projet JonAS : 5 12

13 JONAS_ROOT deploy bin conf libs templates examples logs Repositories Tous les fichiers de configuration de JonAS sont dans le répertoire conf. Ils peuvent être modifiés mais cela va impacter toutes les applications déployés sur JonAS, ce qui peut être un inconvénient car toutes les applications n utilisent pas forcément la même base de données, ni le même protocole d appels d objets. C est pour cette raison que les concepteurs du projet JonAS ont pensé à permettre la création d un environnement spécifique pour la configuration et le déploiement des applications tournant sur JonAS : ce environnement est créé à travers des scripts présents dans JONAS_ROOT/bin et configuré via la variable JONAS_BASE. JONAS_BASE deploy lib conf work logs Repositories 13

14 En plus de la création de la JONAS_BASE, on a également dans le cadre de ce projet, fait un certain nombre de choix au niveau de certains paramètres de JonAS. - le protocole jrmp pour les échanges via RMI, ce protocole est plus efficace qu IIOP pour les échanges Java-Java (c est-à-dire à la fois le client et le serveur doivent être codés en Java). Jonas permet la modification de ce protocole à l intérieur même du code de l application. Pour cela il suffit d intégrer le fichier carol.properties à la base du projet et de modifier la ligne # jonas rmi activation (iiop, irmi, jrmp) carol.protocols=jrmp - Compte tenu des choix techniques que nous avons fait pour l implémentation de l application Mailbox, nous avons du paramétrer JonAS afin qu il fonctionne avec une base de données MySQL. Pour cela, il faut : Mettre le connecteur MySQL dans les librairies de JONAS_BASE Configurer le fichier jonas.properties en modifiant les lignes Activation du service de base de données: jonas.services jtm,dbm,security,resource,ejb3,jaxws,web,ear,depmonitor Le datasource : jonas.service.dbm.datasources Mysql1 Ensuite il faut créer le fichier Mysql1.properties avec toutes les données permettant la connexion à la base de donnée (login, mot de passe, adresse,.) datasource.name datasource.url datasource.classname datasource.username datasource.password datasource.mapper CSC5002_9 jdbc:mysql://www-inf.it-sudparis.eu:3306/csc5002_9 com.mysql.jdbc.driver adm_csc5002_9 Monday11October rdb.mysql 14

15 Une fois configuré, JonAS se lance simplement par la commande jonas start ; pour l arrêter il faut taper jonas stop. La commande jonas admin permet d administrer le serveur en ligne de commande, ce mode permet notamment de voir les Beans déployés sur le serveur, ce qui est très utile. 4. Développement du Mailbox sous JonAS Dans cette partie, nous abordons le développement et le déploiement de l application Mailbox sous JonAS. Pour faire ce travail, nous sommes partis de l application que nous avions déjà développée sous Glassfish, notre idée était de l adapter afin qu elle puisse tourner sous JonAS. d) Ce qui a été conservé L architecture de l application n a pas été changé, ainsi que sa conception. e) Ce qui a été modifié La persistance Nous avons du modifier le modèle de persistance pour l adapter à JonAS. Tout de même, JPA a été conservé, c est son implémentation qui a été changé. On a ainsi du mettre Hibernate à la place de EclipseLink qui n est pas supporté pas JonAS 5.1. Cela vient du fait que l implémentation JPA 2.0 est apparue après le serveur JonAS 5.1. Modifications dans jonas.properties : Le provider # Set the JPA provider: hibernate or eclipselink jonas.service.ejb3.jpa.provider hibernate Quelques lignes du fichier de persistance (persistence.xml) <?xml version="1.0" encoding="utf-8"?> <persistence xmlns="http://java.sun.com/xml/ns/persistence" version="1.0"> <persistence-unit name="pu1"> <provider></provider> <jta-data-source>csc5002_9</jta-data-source> <properties> <property name="hibernate.dialect" value="org.hibernate.dialect.mysqldialect"/> <property name="hibernate.hbm2ddl.auto" value="update"/> <property name="eclipselink.ddl-generation" value="drop-and-create-tables"/> <property name="eclipselink.ddl-generation.output-mode" value="database"/> 15

16 <property name="eclipselink.target-database" value="mysql"/> <property name="toplink.target-database" value="mysql"/> <property name="toplink.ddl-generation" value="drop-and-create-tables"/> <property name="toplink.ddl-generation.output-mode" value="database"/> <property name="openjpa.jdbc.dbdictionary" value="mysql"/> <property name="openjpa.jdbc.synchronizemappings" value="buildschema(foreignkeys=true)"/> </properties> </persistence-unit> </persistence> Le déploiement Nous avons été surpris par l écart existant entre le déploiement que nous avions fait sur Glassfish et ce que nous devions faire pour que l application fonctionne sous jonas. C est la partie qui nous a le plus pris du temps. Sous Glassfish on avait un plan de déploiement relativement simple, un fichier build.xml qui généré un jar à travers l outil ANT et qui est directement déployable sur le serveur. Notre premier réflexe a été d essayer la même technique sous JonAS. Nous avons ainsi généré un jar que nous avons essayé de déployé sur JonAS, sans succès. On a notamment pas pu résoudre le cette erreur The given filename Mailbox.jar is not an absolute file. La deuxième solution a été de packager le projet dans un fichier EAR. Que contient le fichier EAR? Tout d abord un fichier EAR est un fichier jar pour lequel on a changé l extension. Il est utilisé par Java EE pour empaqueter un ou plusieurs 'modules' dans une seule archive, de façon à pouvoir déployer ces modules sur un serveur d'applications en une seule opération, et de façon cohérente. Ces archives contiennent aussi des fichiers XML appelés descripteurs de déploiement, qui indiquent comment les modules doivent être déployés sur le serveur. 6 Ainsi dans notre cas le fichier EAR est structuré comme suit : 6 16

17 Client Administrateur AdministratorClient.jar Client Utilisateur MailBoxclient.jar EAR Module EJB Ejb3.jar META-INF descripteurs de deploiement Figure 9 - Structure d'un EAR o Les clients Chaque client (Admin et Mailbox) est un fichier jar qui contient la classe compilée du client et son propre descripteur de déploiement. Client Administrator.jar AdministratorClient.class META-INF applicationclient.xml o Le module EJB Figure 10 - Struture du client Le module EJB (fichier jar) contient les classes métiers compilées de l application (les bean et les entity). De plus il embarque un répertoire META-INF contenant le fichier de persistance. EJB3.jar Ejb DirectoryManager DirectoryManagerBean MailBoxManager MailBoxManagerBean User Message Entity META-INF persistence.xml 17

18 o Comment est généré le fichier EAR? Pour voir comment ce fichier est généré, nous allons introduire la structure du projet Mailbox sous Jonas etc : dans ce répertoire, on retrouve le fichier de persistance et les descripteurs de déploiement des modules de l application include : contenant un fichier XML (jonas-common.xml) rassemblant quelques éléments utiles au fichier build.xml. Ce fichier sera inclus dans build.xml, il est là pour éviter de trop surcharger ce dernier. src : qui contient le code source des classes JAVA de l application bin-client/clientconfig : contenant les paramètres JNDI et le protocole de communication le fichier build.xml Le fichier build.xml contient les instructions nécessaires pour la compilation et le packaging des modules de l application Mailbox au travers de l outil ANT. Cela permet entre autre ce générer le fichier EAR - Prise en charge du fichier EAR par jonas A la fin de la compilation à travers ANT, le fichier EAR (maibox.ear) est déposé dans le répertoire deploy de JONAS_BASE. Jonas prend directement en compte le fichier et déploie l application. On n a pas besoin de redémarrer le serveur. Pour lancer les client de l application, on disposent de deux méthodes: 18

19 1. La commande Jclient Avec la commande ci-dessous, on lance le client Administrator, jclient -nowsgen $JONAS_BASE/deploy/mailbox.ear -jarclient administratorclient.jar L'option -jarclient permet de spécifier le client à utiliser cr l'application Mailbox en a deux. Sachant que cette méthode n'est pas conforme à la spécification Java EE, la commande jclient devrait être supprimée dans les prochaines versions de JonAS 2. Le conteneur client Pour se conformer à la spécification Java, Jonas propose un "conteneur" client qui dispose de toutes les classes pour lancer le client de l'application. Ce conteneur est un fichier jar (client.jar) qui se trouve dans $JONAS_ROOT/lib 7. Ainsi pour lancer le client Administrator il faut taper: java -jar client.jar $JONAS_ROOT/lib/client.jar -jarclient AdministratorClient.jar mailbox.ear En plus du client à lancer (option -jarclient), il fut également donner le nom du package EAR qui contient ce client. Pour permettre l'exécution du client sur une machine distance, on doit spécifier les paramètre JNDI et le protocole de connexion. Ces informations doivent être mises dans le fichier carol.properties de JONAS. Exemple l'adresse du serveur se traduit par la ligne: carol.irmi.url=rmi:// :1099 Ce fichier peut être utilisé à différents niveaux. Le fichier carol.properties est recherché en respectant les priorités suivantes, par ordre décroissant: - Le fichier carol.properties spécifié par l'argument -carolfile du conteneur client - le fichier carol.properties packagé dans l'application client (le jar client) - si il n'a pas été trouvé selon les deux méthodes précédentes, le fichier carol.properties contenu dans le fichier JONAS_ROOT/lib/client.jar sera utilisé. Dans notre projet nous avons choisi la deuxième méthode, c'est à dire intégrer le fichier carol.properties dans le projet

20 Code Dans la partie précédente nous avons expliqué le travail qui a été fait pour déployer l application Mailbox sous JonAS avec notamment le développement des descripteurs de déploiement des modules applicatifs. D autres changements sont à noter également au niveau du code source - La recherche d un bean Jonas a sa propre nomenclature des beans que le serveur déploie, pour accéder à un bean il faut donc se conformer aux noms des beans générés à travers le JNDI (Java Naming and Directory Interface). Code de recherche d un bean (ci-dessous celui du bean d administration DirectoryManager) private static final String JNDI_NAME = "ejb.directorymanagerbean" + "_" + DirectoryManager.class.getName() + Context InitialContex = new InitialContext(); directorymanager = (DirectoryManager) InitialContex.lookup(JNDI_NAME); Un autre moyen pour résoudre ce problème est de remplacer le paramètre name de sur Glassfish par le paramètre mappedname de la même annotation sur JonAS. En effet name ne fonctionne pas sur JonAS. - Le type de retour d'une requête Une autre différence est le type de retour d une requête au travers de l entity manager. Lorsque par exemple on envoie une requête qui retourne tous les utilisateurs présents en base, sous Glassfish on l obtenait dans un vecteur alors que sous Jonas on a une ArrayList. Cela peut être du également à une différence entre Hibernate et EclipseLink La requête: query = entitymanager.createquery("select user FROM User user"); Resultant sous Glassfish: Vector<User> userlist = (Vector<User>) query.getresultlist(); Resultat sous JonAS: ArrayList<User> userlist = (ArrayList<User>) query.getresultlist(); 20

21 VI. Déploiement sous SPRING Nous avons dernièrement essayé de déployer le programme sous Spring. Cette partie décrit les différents solution nous avons testées. 1. Introduction au Spring Framework Spring est un conteneur dit «léger», c'est-à-dire une infrastructure similaire à un serveur d'application Java EE. Il prend donc en charge la création d'objets et la mise en relation d'objets par l'intermédiaire d'un fichier de configuration qui décrit les objets à fabriquer et les relations de dépendances entre ces objets. Le gros avantage par rapport aux serveurs d'application est qu'avec Spring, les classes n'ont pas besoin d'implémenter une quelconque interface pour être prises en charge par le framework (au contraire des serveurs d'applications Java EE et des EJBs). C'est en ce sens que Spring est qualifié de conteneur «léger». La mise en place de Spring n a pas besoin d un procédure d installation. Il faut simplement télécharger le fichier compressé en forme de ZIP du Spring 3.0 sur le lien Ce framework s'intègre parfaitement dans Eclipse. Nous avions cru au début que la mise en place de programme sous Spring est une procédure simple ne nécessitant pas beaucoup de modification de code. Mais on s'est aperçu que c'est un framework totalement différent des EJB. Figure 11 - Besoin de développeur de Spring et de EJB

22 5. Solutions proposées de déploiement Dans cette partie, nous allons décrire les différents méthodes effectuées pour déployer le programme Mailbox sous Spring Framework. f) L intégration d EJBs Comme un conteneur léger, Spring est souvent considéré comme un remplacement d EJB. Mais avec la version de Spring 2.5.0, on peut accéder à des EJB et mettre en œuvre des EJBs. Nous avons commencé notre déploiement avec cette solution. Comme la documentation mentionne, Il faut simplement créer un class qui hérite AbstractStatelessSessionBean 9 pour les EJBs 2.x: public class MyFacadeEJB extends AbstractStatelessSessionBean implements MyFacadeLocal { private MyComponent mycomp; //Obtain our POJO service object from the BeanFactory/ApplicationContext protected void onejbcreate() throws CreateException { mycomp = (MyComponent) getbeanfactory().getbean( ServicesConstants.CONTEXT_MYCOMP_ID); } public String myfacademethod(...) { return mycomp.mymethod(...); }... } Mais nous avons utilisé EJB3. EJB est beaucoup simplifié avec cette nouvelle version. Il n y plus de EJB Remote et EJB Home et on n a plus besoin de descripteur ejb-jar.xml pour déployer. Spring nous propose alors la solution suivante pour EJB3: 9 22

23 public class MyFacadeEJB implements MyFacadeLocal private MyComponent mycomp; // for business method, delegate to POJO service impl. public String myfacademethod(...) { return mycomp.mymethod(...); }... } Nous avons donc testé cette solution mais sans réussite. L donne toujours une erreur. g) Redévelopper la couche intermédiaire avec JdbcTemplate Après l échec d intégrer EJB au Spring, nous avons ensuite essayé à redévelopper la couche intermédiaire du programme. Spring a nous offert JdbcTemplate comme une approche simple pour les échanges avec les base de donnée. Nous avons tout à bord créé une nouvelle classe pour configurer l accès à base de données. 23

24 @Configuration public class JdbcConfig public JdbcTemplate jdbctemplate() { DriverManagerDataSource datasource = new DriverManagerDataSource(); } } datasource.setdriverclassname("com.mysql.jdbc.driver"); datasource.seturl("xxxxx"); datasource.setusername("xxxx"); datasource.setpassword("xxxx"); return new JdbcTemplate(dataSource); Avec cette classe, on peut insérer un enregistrement comme la méthode suivante : jdbctemplate.update("insert into User values (?, true, true, true, true,?)", login, password); Et on peut également faire des requête comme la façon : jdbctemplate.queryforobject ("select "); La manipulation des requêtes marchent très bien avec cette solution. Mais la difficulté reste la persistance de donnée. Spring ne connait rien sur la relation entre les deux tables car on n a pas une entity manager (type JPA) qui gère la persistance de donnée. Ceci rend le développement beaucoup plus complexe. Nous avons réalisé les fonctionnalités d AdministratorClient. Mais nous avons aperçu que ce n est pas une bonne méthode sans utiliser un gestionnaire de persistance. Il nous donc trouver une autre meilleure solution qui encapsule les manipulations en relation avec la base de donnée. h) Solution Spring + Hibernate Notre encadrante nous a donc proposé d utiliser Hibernate. Hibernate est un framework open source gérant la persistance des objets en base de données relationnelle et l'avions déjà mis en œuvre sur JonAS. Il permet de «mapper» une base de données relationnelle en 24

25 objets. Il permet donc d abstraire totalement l accès à la base de données et propose donc un accès totalement orienté objet aux données. Nous avons créé une interface qui abstrait les actions sur la table User 10 : public interface UserDao { } public Collection<User> findusers() throws DataAccessException; public Collection<User> findusersbyid(string id) throws DataAccessException; public void save(user person); } Nous avons ensuite crée une nouvelle classe qui implémente cette interface :

26 = true) public class UserDaoImpl implements UserDao { } protected HibernateTemplate template = null; public void setsessionfactory(sessionfactory sessionfactory) { template = new public Collection<User> findusers() throws DataAccessException { return template.find("from User"); public Collection<User> findusersbyid(string id) throws DataAccessException { } return template.find("from User u where u.user_login =?", id); public void save(user person) { } template.saveorupdate(person); Cette solution doit normalement fonctionner mais en raison de l échéance du projet, nous n avons pas eu assez du temps pour la terminer. 26

27 VII. Comparaison de performances Dans cette partie, nous allons d une part comparer l implémentation du Mailbox avec la spécification EJB 3.0 sous JonAS et Glassfish, d autre part nous allons voir les différences entre les EJB et l implémentation proposée par Spring. 6. Glassfish VS Jonas i) Comparaison qualitative Certification Java EE, communauté et documentation Pour commencer cette comparaison, nous allons aborder les certifications Java EE qui sont un gage de performance des serveurs d applications. Sur ce point là il ne fait aucun doute que Glassfish est en avance. Ceci peut s expliquer par le fait que Glassfish est développé au sein de SUN (maintenant Oracle), la même entreprise qui développe les spécifications Java EE et EJB. Concrètement, la dernière version de Glassfish (v3) est déjà certifiée Java EE 6 tandis que Jonas 5.1 est certifiée Java EE 5 même si la version en cours de développement intègre déjà quelques éléments de Java EE Pour ce qui concerne la communauté et la documentation, là aussi Glassfish garde la main grâce au soutien de la forte communauté, par contre avec JonAS on a plus d'exemples fournis avec le serveur, ce qui est très utile pour comprendre le fonctionnement du serveur. Persistance Les deux serveurs intègre JPA 1.0 et proposent plusieurs supports pour JPA 1.0 notamment Hibernate, EclipseLink, Open JPA. Dans ce projet nous ne sommes tout de même pas arrivés à faire fonctionner JonAS et EclipseLink. A noter également que Glassfish V3 intègre JPA 2.0, ce qui n est pas le cas pour l instant des versions Stable de JonAS. Code source Pour la partie codage, nous pouvons mentionner tout d abord que les deux projets proposent des plugins Eclipse pour leur administration (JOPE 12 pour JonAS, Tools Bundle pour Glassfish 13 ). Nous avons testé ces outils, ils permettent de démarrer/stopper/configurer les serveurs. Quand à la possibilité de créer des projets préconfigurés pour fonctionner sur les serveurs, là c est plus mitigé. Tools Bundle est plus orienté projets Web tandis que JOPE ne fonctionne malheureusement qu avec des versions anciennes d Eclipse (il ne fonctionne pas sous Galileo et Helios par exemple). En ce qui concerne les différences dans les développements des applications, à part les quelques modifications mentionnées dans la partie VI.4, il n'y a pas énormément d'efforts de

28 modification de code à faire pour passer d'une application Java EE tournant JonAS vers Glassfish et vice versa. En effet les deux serveurs intègre très bien la spécification des EJB 3.0, le seul soin à apporter lors du développement est de se conformer à cette spécification. Déploiement Nous avons déployé l'application Mailbox écrite en Java EE sous deux formes, une fichier jar classique pour Glassfish et un fichier EAR pour JonAS. La méthode utilisant les EAR est probablement la plus propre surtout lorsque l'on a plusieurs modules EJBs dans l'application. Ce modèle permet d'avoir l'ensemble des modules dans un seul package. A contrario, elle demande un effort de développement supplémentaire, notamment pour l'écriture des descripteurs de déploiement car chaque module de l'application doit être packagé dans un jar. La deuxième méthode est le paquetage des classes dans un jar qui va ensuite être déployé dans le serveur d'applications. Cette méthode convient pour des applications de petite taille et qui n'ont pas beaucoup de modules et qui ne demande pas énormément d'interactions entre les modules, ce qui le cas du Mailbox. Administration Les deux serveurs offrent deux modes d'administration: à travers console web ou en ligne de commandes. Les consoles web offrent à peu près les mêmes possibilités avec notamment la possibilité de : - Configurer le serveur - Configurer des services (bases de données, réseau, sécurité,...) - Gérer les applications (déploiement,...). Glassfish donne la possibilité d'activer le monitoring de certains services (JVM, JPA, conteneur EJB,...). Il faut toutefois noter que l'outil de monitoring qui permet d'avoir la représentation graphique des valeurs générées n'est pas inclus dans la version libre mais uniquement dans la version Entreprise de Glassfish. On peut tout de même récupérer ces valeurs à l'aide de dtrace (système de trace conçu par Sun Microsystems). En ce qui concerne le monitoring du coté de JonAS, il existe un outil (JASMINe) qui permet entre autres de superviser des services JonAS ou encore. JASMINe est open source comme Jonas, ce qui représente un bon point pour le serveur. Figure 12 - Console JASMINe 28

Compte Rendu d intégration d application

Compte Rendu d intégration d application ISMA 3EME ANNEE Compte Rendu d intégration d application Compte Rendu Final Maxime ESCOURBIAC Jean-Christophe SEPTIER 19/12/2011 Table des matières Table des matières... 1 Introduction... 3 1. Le SGBD:...

Plus en détail

JOnAS 5. Serveur d application d

JOnAS 5. Serveur d application d JOnAS 5 Serveur d application d dynamique Agenda En quelques mots Caractéristiques essentielles Zoom sur le versioning 2 Bull, 2008 Serveur d application dynamique JOnAS - Serveur d application Open Source

Plus en détail

Institut 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 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étail

1. Installation d'un serveur d'application JBoss:

1. Installation d'un serveur d'application JBoss: EPITA Ala Eddine BEN SALEM App-Ing2 J2EE T.P. 4 EJB3, Serveur d'application JBoss 1. Installation d'un serveur d'application JBoss: télécharger l'archive du serveur JBoss à l'adresse: http://sourceforge.net/projects/jboss/files/jboss/jboss-5.0.0.ga/jboss-5.0.0.ga.zip/download

Plus en détail

Guide Pratique EDI NetBeans

Guide Pratique EDI NetBeans Guide Pratique EDI NetBeans Copyright 2005 Sun Microsystems, Inc. All rights reserved. Table des matières Assistant type de Projet EJB...2 Structure Module EJB...5 Ajout d'ejb, Fichiers et Bibliothèques

Plus en détail

Création d une application JEE

Cré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étail

Apache Tomcat 8 Guide d'administration du serveur Java EE 7 sous Windows et Linux

Apache Tomcat 8 Guide d'administration du serveur Java EE 7 sous Windows et Linux Avant-propos 1. À qui s adresse ce livre? 11 2. Les pré-requis 12 Préambule 1. Rappel sur les architectures Internet/Intranet/Extranet 13 1.1 Le protocole HTTP 14 1.1.1 Les méthodes HTTP 16 1.1.2 Les codes

Plus en détail

Java pour le Web. Cours Java - F. Michel

Java pour le Web. Cours Java - F. Michel Java pour le Web Cours Java - F. Michel Introduction à JEE 6 (ex J2EE) Historique Qu'est-ce que JEE JEE : Java Entreprise Edition (ex J2EE) 1. Une technologie outils liés au langage Java + des spécifications

Plus en détail

JOnAS Day 5.1. Outils de développements

JOnAS Day 5.1. Outils de développements JOnAS Day 5.1 Outils de développements Agenda Introduction Plugin Eclipse (JOPE) Plugin NetBeans (JOnbAS) Cargo 2 Bull, 2009 JOnAS Day 5.1 Objectifs - Réduire les temps de développement - Construction

Plus en détail

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)

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) 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étail

Refonte front-office / back-office - Architecture & Conception -

Refonte front-office / back-office - Architecture & Conception - Refonte front-office / back-office - Architecture & Conception - GLG204 - Architectures Logicielles Java 2008/2009 Nom : Cédric Poisson Matricule : 06-49012 Version : 1.0 Jeudi 28 mai 2009 1 / 23 Table

Plus en détail

Auto-évaluation Aperçu de l architecture Java EE

Auto-évaluation Aperçu de l architecture Java EE Auto-évaluation Aperçu de l architecture Java EE Document: f1218test.fm 22/03/2012 ABIS Training & Consulting P.O. Box 220 B-3000 Leuven Belgium TRAINING & CONSULTING INTRODUCTION AUTO-ÉVALUATION APERÇU

Plus en détail

Architecture J2EE. Thierry Lecroq (merci à Alexandre Pauchet (INSA Rouen)) Université de Rouen FRANCE. Thierry Lecroq (Univ. Rouen) J2EE 1 / 16

Architecture J2EE. Thierry Lecroq (merci à Alexandre Pauchet (INSA Rouen)) Université de Rouen FRANCE. Thierry Lecroq (Univ. Rouen) J2EE 1 / 16 Architecture J2EE Thierry Lecroq (merci à Alexandre Pauchet (INSA Rouen)) Université de Rouen FRANCE Thierry Lecroq (Univ. Rouen) J2EE 1 / 16 Plan 1 Historique 2 Architecture J2EE 3 J2EE et applications

Plus en détail

EXA1415 : Annotations JavaEE : @Local, @Stateful

EXA1415 : Annotations JavaEE : @Local, @Stateful EXA1415 : Annotations JavaEE : @Local, @Stateful Sur une idée de P. Sécheresse sur http://developpez.com (http://tinyurl.com/5gr57j) Diapo 1 Objectif Créer un EJB CalculatriceBean (V1) Contient une opération

Plus en détail

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

24/11/2011. Cours EJB/J2EE Copyright Michel Buffa. Plan du cours. EJB : les fondamentaux. Enterprise Java Bean. Enterprise Java Bean. Plan du cours 2 Introduction générale : fondamentaux : les fondamentaux Michel Buffa (buffa@unice.fr), UNSA 2002, modifié par Richard Grin (version 1.1, 21/11/11), avec emprunts aux supports de Maxime

Plus en détail

Répertorier les couches de présentation

Répertorier les couches de présentation Comprendre le fonctionnement d une application J2EE Déploiement Fichiers de configurations Relation avec la DB Objets Application J2EE de base Appli marchand simple Répertorier les couches de présentation

Plus en détail

Environnements de Développement

Environnements de Développement Institut Supérieur des Etudes Technologiques de Mahdia Unité d Enseignement: Environnements de Développement BEN ABDELJELIL HASSINE Mouna m.bnaj@yahoo.fr Développement des systèmes d Information Syllabus

Plus en détail

Mise en œuvre des serveurs d application

Mise en œuvre des serveurs d application Nancy-Université Mise en œuvre des serveurs d application UE 203d Master 1 IST-IE Printemps 2008 Master 1 IST-IE : Mise en œuvre des serveurs d application 1/54 Ces transparents, ainsi que les énoncés

Plus en détail

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

Avant-propos 1. Avant-propos...3 2. Organisation du guide...3 3. À qui s'adresse ce guide?...4 Les exemples cités tout au long de cet ouvrage sont téléchargeables à l'adresse suivante : http://www.editions-eni.fr. Saisissez la référence ENI de l'ouvrage EP5EJAV dans la zone de recherche et validez.

Plus en détail

Introduction à la plateforme J2EE

Introduction à la plateforme J2EE Introduction à la plateforme J2EE Auteur : Oussama Essefi Directeur technique Expert Consulting Oussama.essefi@expert-consulting.biz Copyright 2010 Expert Consulting Page 1 1. Introduction 1.1. Pourquoi

Plus en détail

Types d applications pour la persistance. Outils de développement. Base de données préexistante? 3 modèles. Variantes avec passerelles

Types d applications pour la persistance. Outils de développement. Base de données préexistante? 3 modèles. Variantes avec passerelles Types d applications pour la persistance Université de Nice Sophia-Antipolis Version 0.9 28/8/07 Richard Grin Toutes les applications n ont pas une complexité qui nécessite une architecture n- tiers Ce

Plus en détail

TP J2EE GUIDE DE DEPLOIEMENT DE L APPLICATION WEB DE GESTION DES COMPTES

TP J2EE GUIDE DE DEPLOIEMENT DE L APPLICATION WEB DE GESTION DES COMPTES 2008 UFR Ingénieurs 2000 Vivien Boistuaud Julien Herr TP J2EE GUIDE DE DEPLOIEMENT DE L APPLICATION WEB DE GESTION DES COMPTES Ce document a été réalisé par V. Boistuaud et J. Herr dans le cadre des travaux

Plus en détail

JOnAS Day 5.1. Clustering

JOnAS Day 5.1. Clustering JOnAS Day 5.1 Clustering Solution complète de clustering Répartition de charge & bascule sur échec Application Web avec mod_jk/mod_proxy Connecteur http pour md_proxy Application Ejb avec CMIv2 Réplication

Plus en détail

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

Architecture JEE. Objectifs attendus. Serveurs d applications JEE. Architectures JEE Normes JEE. Systèmes distribués Architecture JEE. Objectifs attendus Serveurs d applications JEE Systèmes distribués Architectures JEE Normes JEE couches logicielles, n-tiers framework JEE et design patterns 2007/02/28 Eric Hébert.eheb@yahoo.fr

Plus en détail

Site Web de paris sportifs

Site Web de paris sportifs Conception Nom HENAUD Benoît Numéro d auditeur 05-39166 Version V1.1 Date de mise à jour 15/05/2008 1/18 Table des matières 1. Objectif du document... 3 2. Architecture... 4 2.1. Contraintes techniques...

Plus en détail

Cahier de charges (Source : "Java EE - Guide de développement d'applications web en Java" par Jérôme Lafosse) Module. Site Web dynamique JSP / Servlet

Cahier de charges (Source : Java EE - Guide de développement d'applications web en Java par Jérôme Lafosse) Module. Site Web dynamique JSP / Servlet Cahier de charges (Source : "Java EE - Guide de développement d'applications web en Java" par Jérôme Lafosse) Module Site Web dynamique JSP / Servlet Sujet : betaboutique Soutenance le 04 / 01 /2013 &

Plus en détail

JOnAS 5 Enterprise OSGi javaee compliant

JOnAS 5 Enterprise OSGi javaee compliant JOnAS 5 Enterprise OSGi javaee compliant Agenda Introduction Architecture JOnAS 5 Embarqué 2 Bull, 2009 Diffusion non autorisée sans accord préalable Serveur d'application de classe entreprise - 1er serveur

Plus en détail

Apache Tomcat 8. Guide d administration du serveur Java EE 7 sous Windows et Linux. Apache Tomcat 8. Apache Tomcat 8

Apache Tomcat 8. Guide d administration du serveur Java EE 7 sous Windows et Linux. Apache Tomcat 8. Apache Tomcat 8 Avant-propos Préambule La plate-forme Java EE Installation et configuration Administration du serveur Déploiement et gestion des applications La sécurité du serveur et des applications Analyse et supervision

Plus en détail

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

La persistance des données dans les applications : DAO, JPA, Hibernate... COMPIL 2010 francois.jannin@inp-toulouse.fr 1 La persistance des données dans les applications : DAO, JPA, Hibernate... COMPIL 2010 francois.jannin@inp-toulouse.fr 1 Plan 1. Généralités sur la persistance des données dans les applications 2. La connection

Plus en détail

Cedric Dumoulin (C) The Java EE 7 Tutorial http://docs.oracle.com/javaee/7/tutorial/doc/

Cedric Dumoulin (C) The Java EE 7 Tutorial http://docs.oracle.com/javaee/7/tutorial/doc/ Cedric Dumoulin (C) The Java EE 7 Tutorial http://docs.oracle.com/javaee/7/tutorial/doc/ Webographie The Java EE 7 Tutorial http://docs.oracle.com/javaee/7/tutorial/doc/ Les slides de cette présentation

Plus en détail

J2EE - Introduction. Développement web - Java. Plan du chapitre

J2EE - Introduction. Développement web - Java. Plan du chapitre Développement web - Java J2EE - Introduction Franck Denoël Master 2 ICA, UPMF Année académique 2007-2008 Franck Denoël Master 2 ICA, UPMF Année académique 2007-2008 Plan du chapitre J2EE Présentation J2EE

Plus en détail

Quick Start Installation de MDweb version 2.3

Quick Start Installation de MDweb version 2.3 Quick Start Installation de MDweb version 2.3 Date : 2011.08.26 1. Quickstart Quick Start - Installation de MDweb version 2011 Installation Téléchargement et Installation des logiciels requis Déploiement

Plus en détail

Programmation d applications distribuées

Programmation d applications distribuées Programmation d applications distribuées François Charoy Université Henri Poincaré 8 octobre 2007 Première partie I Développement d applications distribuées Objectifs du cours Comprendre ce qu est une

Plus en détail

EISTI. Oracle Toplink. Manuel d installation et d utilisation

EISTI. Oracle Toplink. Manuel d installation et d utilisation EISTI Oracle Toplink Manuel d installation et d utilisation VILLETTE Charles, BEQUET Pierre, DE SAINT MARTIN Cédric, CALAY-ROCHE Vincent, NAUTRE Francois 20/05/2010 Ce manuel d installation et d utilisation

Plus en détail

Intégration avec Camel et ServiceMix

Intégration avec Camel et ServiceMix Charles Moulliard Architecte de Solutions Apache Committer Objectif «Faire découvrir les projets Apache orientés Intégration comme Camel ainsi que le conteneur ServiceMix et les architectures cibles» 3

Plus en détail

Etude de cas PLM. Patrice TORGUET IRIT Université Paul Sabatier

Etude de cas PLM. Patrice TORGUET IRIT Université Paul Sabatier Etude de cas PLM Patrice TORGUET IRIT Université Paul Sabatier Plan Exemple PLM Répartition avec Sockets Répartition avec RMI Répartition avec CORBA Répartition avec JMS Répartition avec Java EE Améliorations

Plus en détail

L Orchestration de Services Web avec Orchestra. Goulven Le Jeune Orchestra Project Manager

L Orchestration de Services Web avec Orchestra. Goulven Le Jeune Orchestra Project Manager L Orchestration de Services Web avec Orchestra Goulven Le Jeune Orchestra Project Manager D1 Bull, Architecte d un Monde Ouvert : contributeur et acteur majeur de l'open Source Applications métiers Infrastructures

Plus en détail

Connexion à SQL Server 2005 à partir du serveur d application SJSAS 9 Utilisation d une interface JDBC

Connexion à SQL Server 2005 à partir du serveur d application SJSAS 9 Utilisation d une interface JDBC Connexion à SQL Server 2005 à partir du serveur d application SJSAS 9 Utilisation d une interface JDBC Sommaire 1. Objectifs et intérêts... 2 2. Intégrer le driver SQL Server dans SJSAS 9... 2 2.1. Télécharger

Plus en détail

Serveur d'application à la juste taille

Serveur d'application à la juste taille Serveur d'application à la juste taille 18 Mars 2010 Benoit.Pelletier@bull.net Plan Contexte JOnAS 5, plate-forme de convergence JavaEE/OSGi Caractéristiques essentielles pour le Cloud Computing & l'autonomic

Plus en détail

Documentation technique MBDS2.0 Site web administratif

Documentation technique MBDS2.0 Site web administratif Documentation technique MBDS2.0 Site web administratif Le document suivant est destiné aux développeurs souhaitant installer la plateforme sur leurs propres machines. D o c u m e n t a t i o n t e c h

Plus en détail

Architecture de la plateforme SBC

Architecture de la plateforme SBC Simple Business Connector Architecture de la plateforme SBC Titre Projet Description Architecture de la plateforme SBC Plateforme SBC Ce document reprend toutes les étapes de l'installation du serveur

Plus en détail

Manuel d'utilisation de la console de supervision

Manuel d'utilisation de la console de supervision Manuel d'utilisation de la console de supervision Ce document décrit la mise en route et l'utilisation de la console d'administration web de PEtALS. EBM WebSourcing (MarieSauvage) - Mai 2007 - (CC) EBM

Plus en détail

Java Naming and Directory Interface

Java 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étail

Tutoriel d installation de Hibernate avec Eclipse

Tutoriel d installation de Hibernate avec Eclipse Tutoriel d installation de Hibernate avec Eclipse Table des matières 1. Création de la base de données... 4 2. Installation de Hibernate Synchronizer... 5 3. Utilisation de Hibernate... 6 3.1 Création

Plus en détail

Le moteur de workflow JBPM

Le moteur de workflow JBPM Le moteur de workflow Claude Duvallet Université du Havre UFR Sciences et Techniques 25 rue Philippe Lebon - BP 540 76058 LE HAVRE CEDEX Claude.Duvallet@gmail.com http://litis.univ-lehavre.fr/ duvallet/

Plus en détail

Le moteur de workflow JBPM

Le moteur de workflow JBPM Le moteur de Workflow Le moteur de workflow 1 Claude Duvallet Université du Havre UFR Sciences et Techniques 25 rue Philippe Lebon - BP 540 76058 LE HAVRE CEDEX Claude.Duvallet@gmail.com http://litis.univ-lehavre.fr/

Plus en détail

E-mail : contact@nqicorp.com - Web : http://www.nqicorp.com

E-mail : contact@nqicorp.com - Web : http://www.nqicorp.com - 5, rue Soutrane - 06560 Valbonne Sophia-Antipolis E-mail : contact@nqicorp.com - Web : http://www.nqicorp.com NQI Orchestra 3.3 - Guide d'installation Windows.................................................................

Plus en détail

EJB 3 : Session & Entity Beans

EJB 3 : Session & Entity Beans Première Partie (mise en place) EJB 3 : Session & Entity Beans 1) Faites la partie requirements de ce document avant la suite Deuxième Partie (Un petit tutorial pour commencer avec les Stateless session

Plus en détail

Formation en Logiciels Libres. Fiche d inscription

Formation en Logiciels Libres. Fiche d inscription République Tunisienne Ministère de l'industrie et la Technologie - Secrétariat d'état de la Technologie Unité des Logiciels Libres Formation en Logiciels Libres Fiche d inscription (Une fiche par candidat)

Plus en détail

Groupe Eyrolles, 2004, ISBN : 2-212-11346-3

Groupe Eyrolles, 2004, ISBN : 2-212-11346-3 Groupe Eyrolles, 2004, ISBN : 2-212-11346-3 Table des matières Avant Propos................................................ 1 Pourquoi ce livre?........................................... 1 Structure de

Plus en détail

Application web de gestion de comptes en banques

Application web de gestion de comptes en banques Application web de gestion de comptes en banques Objectif Réaliser une application Web permettant à un client de gérer ses comptes en banque Diagramme de cas d'utilisation 1 Les cas d'utilisation Connexion

Plus en détail

Documentation de la plate forme JOnAS

Documentation de la plate forme JOnAS Documentation de la plate forme JOnAS Documentation de la plate forme JOnAS Table des matières Documentation JOnAS...1 Java Open Application Server (JOnAS): une Plate forme J2EETM...3 Introduction...3

Plus en détail

Documentation de la plate forme JOnAS. Frederic Maistre

Documentation de la plate forme JOnAS. Frederic Maistre Documentation de la plate forme JOnAS Frederic Maistre Documentation de la plate forme JOnAS Table des matières Documentation JOnAS...1 Java Open Application Server (JOnAS): une Plate forme J2EETM...3

Plus en détail

XML et Bases de données. XMLType Oracle XML DB

XML et Bases de données. XMLType Oracle XML DB Oracle XML DB Oracle XML DB Depuis la version 9i et de façon enrichie dans la version 10g, Oracle propose des outils pour gérer des documents XML Depuis la 10g il n'y a plus d'extraction car auparavant

Plus en détail

Architecture des systèmes d information

Architecture des systèmes d information Architecture des systèmes d information Table des matières 1 La décennie 70 1 2 Le modèle relationnel (les années 80) 1 3 Enrichissement du relationnel (les années 80/90) 2 4 Système d informations (les

Plus en détail

NOVA BPM. «Première solution BPM intégr. Pierre Vignéras Bull R&D

NOVA BPM. «Première solution BPM intégr. Pierre Vignéras Bull R&D NOVA BPM «Première solution BPM intégr grée» Pierre Vignéras Bull R&D Définitions Business Process Pratiques existantes qui permettent aux personnes et systèmes de travailler ensemble Business Process

Plus en détail

Jean-Michel Richer jean-michel.richer@univ-angers.fr http://www.info.univ-angers.fr/pub/richer. L3 Pro Informatique - 2010-2011

Jean-Michel Richer jean-michel.richer@univ-angers.fr http://www.info.univ-angers.fr/pub/richer. L3 Pro Informatique - 2010-2011 1 / 34 Développement Web - Servlet Jean-Michel Richer jean-michel.richer@univ-angers.fr http://www.info.univ-angers.fr/pub/richer L3 Pro Informatique - 2010-2011 2 / 34 Plan Plan 1 Introduction 2 Servlet

Plus en détail

Une (petite) introduction à Spring

Une (petite) introduction à Spring Une (petite) introduction à Spring 1 Introduction Le framework Spring 1 est une boite à outils très riche permettant de structurer, d améliorer et de simplifier l écriture d application JEE. Spring est

Plus en détail

Architecture des applications

Architecture des applications Architecture des applications Table des matières 1 Introduction 1 2 Les classes valeurs 2 2.1 Les Javaeans............................................. 2 2.2 Les différents types de Javaeans...................................

Plus en détail

Europa. Développement JEE 5. avec Eclipse. K a r i m D j a a f a r. A v e c l a c o n t r i b u t i o n d e O l i v i e r S a l v a t o r i

Europa. Développement JEE 5. avec Eclipse. K a r i m D j a a f a r. A v e c l a c o n t r i b u t i o n d e O l i v i e r S a l v a t o r i Développement JEE 5 avec Eclipse Europa K a r i m D j a a f a r A v e c l a c o n t r i b u t i o n d e O l i v i e r S a l v a t o r i Groupe Eyrolles, 2008, ISBN : 978-2-212-12061-5 5 Le projet WTP (Web

Plus en détail

Web Tier : déploiement de servlets

Web Tier : déploiement de servlets Web Tier : déploiement de servlets 1 / 35 Plan 1 Introduction 2 Servlet : Principe de fonctionnement 3 Création et développement sur un serveur JEE 4 Quelques méthodes de l API des servlets 5 Utilisation

Plus en détail

1 JBoss Entreprise Middleware

1 JBoss Entreprise Middleware 1 JBoss Entreprise Middleware Les produits de la gamme JBoss Entreprise Middleware forment une suite de logiciels open source permettant de construire, déployer, intégrer, gérer et présenter des applications

Plus en détail

E-mail : contact@nqicorp.com - Web : http://www.nqicorp.com

E-mail : contact@nqicorp.com - Web : http://www.nqicorp.com - 5, rue Soutrane - 06560 Valbonne Sophia-Antipolis E-mail : contact@nqicorp.com - Web : http://www.nqicorp.com NQI Orchestra 3.3 - Guide d'installation Linux....................................................................

Plus en détail

Programmabilité du réseau avec l'infrastructure axée sur les applications (ACI) de Cisco

Programmabilité du réseau avec l'infrastructure axée sur les applications (ACI) de Cisco Livre blanc Programmabilité du réseau avec l'infrastructure axée sur les applications (ACI) de Cisco Présentation Ce document examine la prise en charge de la programmabilité sur l'infrastructure axée

Plus en détail

M2PLS - M2EID TP SPRING

M2PLS - M2EID TP SPRING M2PLS - M2EID TP SPRING Référence du document : Http://www-lipn.univ-paris13.fr/M2PLS/tp_spring.pdf Dernière modification : 25/11/11 Type de document : Travaux pratiques Rédacteur : Fortier Michael fortier@univ-paris13,fr

Plus en détail

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

Institut Supérieure Aux Etudes Technologiques De Nabeul. Département Informatique Institut Supérieure Aux Etudes Technologiques De Nabeul Département Informatique Support de Programmation Java Préparé par Mlle Imene Sghaier 2006-2007 Chapitre 1 Introduction au langage de programmation

Plus en détail

Internet Information Services (versions 7 et 7.5) Installation, configuration et maintenance du serveur Web de Microsoft

Internet Information Services (versions 7 et 7.5) Installation, configuration et maintenance du serveur Web de Microsoft Introduction à IIS 1. Objectifs de ce livre 13 2. Implémentation d un serveur web 14 2.1 Les bases du web 14 2.2 Les protocoles web 16 2.3 Le fonctionnement d un serveur web 21 2.4 Les applications web

Plus en détail

Filière : M2 informatique Année universitaire : 2014-2015 Cours : Réutilisation et composants TP EJB 2

Filière : M2 informatique Année universitaire : 2014-2015 Cours : Réutilisation et composants TP EJB 2 Université Montpellier II Faculté des Sciences Département Informatique Filière : M2 informatique Année universitaire : 2014-2015 Cours : Réutilisation et composants TP EJB 2 Objectifs du TD Développer

Plus en détail

SITE WEB E-COMMERCE ET VENTE A DISTANCE

SITE WEB E-COMMERCE ET VENTE A DISTANCE Développement d une application JAVA EE SITE WEB E-COMMERCE ET VENTE A DISTANCE PLAN PROJET Binôme ou monôme (B/M): M Nom & Prénom : AIT NASSER Btissam Email : aitnasser.btissam123@gmail.com GSM : Organisme

Plus en détail

Industrialisation des développements Spring dans Eclipse

Industrialisation des développements Spring dans Eclipse C Industrialisation des développements Spring dans Eclipse L objectif de cette annexe est de décrire comment mettre en œuvre une approche dirigée par les modèles afin d industrialiser les développements

Plus en détail

SOA facile avec SCA. Christophe Demarey, Damien Fournier. To cite this version: HAL Id: inria-00531338 https://hal.inria.

SOA facile avec SCA. Christophe Demarey, Damien Fournier. To cite this version: HAL Id: inria-00531338 https://hal.inria. SOA facile avec SCA Christophe Demarey, Damien Fournier To cite this version: Christophe Demarey, Damien Fournier. SOA facile avec SCA. Programmez, Programmez, 2010. HAL Id: inria-00531338

Plus en détail

Mise en œuvre de serveurs d application TD n o 4

Mise en œuvre de serveurs d application TD n o 4 Master IST-IE 2007 08 UE 203d Mise en œuvre de serveurs d application TD n o 4 1 Introduction Dans ce TD, vous implanterez une application cliente, vous étendrez la logique métier sans modifier les clients,

Plus en détail

Gestion d une école. FABRE Maxime FOUCHE Alexis LEPOT Florian

Gestion d une école. FABRE Maxime FOUCHE Alexis LEPOT Florian Gestion d une école FABRE Maxime 2015 Sommaire Introduction... 2 I. Présentation du projet... 3 1- Lancement de l application... 3 Fonctionnalités réalisées... 4 A. Le serveur... 4 1 - Le réseau... 4 2

Plus en détail

Etude de cas : PGE JEE V2

Etude de cas : PGE JEE V2 Arrivés à ce point du tutoriel, nous savons créer une application Web implémentant la persistance des données. Toutefois, le modèle de cette application était simple et composé d'une unique classe et les

Plus en détail

Supervision et infrastructure - Accès aux applications JAVA. Document FAQ. Page: 1 / 9 Dernière mise à jour: 15/04/12 16:14

Supervision 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étail

ADMINISTRATION DE ADOBE LIVECYCLE MOSAIC 9.5

ADMINISTRATION DE ADOBE LIVECYCLE MOSAIC 9.5 ADMINISTRATION DE ADOBE LIVECYCLE MOSAIC 9.5 Informations juridiques Copyright 2010 Adobe Systems Incorporated and its licensors. All rights reserved. Administration d Adobe LiveCycle Mosaic 9.5 13 octobre

Plus en détail

Plan Introduction Généralités Fonctionnement Conclusion Frameworks de composants dynamiques (OSGi)

Plan Introduction Généralités Fonctionnement Conclusion Frameworks de composants dynamiques (OSGi) Frameworks de composants dynamiques (OSGi) M2TI Conception d Applications Hétérogènes Distribuées Lionel Médini Septembre-novembre 2014 Objectifs de ce module Paradigmes de programmation avancés Conteneurs

Plus en détail

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

La base de données XML exist. A. Belaïd La base de données XML exist Introduction Qu est-ce-que exist? C est une base de donnée native, entièrement écrite en Java XML n est pas une base de données en soi Bien qu il possède quelques caractéristiques

Plus en détail

Découvrez JavaEE 5 avec NetBeans 5.5 - partie 1

Découvrez JavaEE 5 avec NetBeans 5.5 - partie 1 Découvrez JavaEE 5 avec NetBeans 5.5 - partie 1 par Date de publication : 17/06/06 Dernière mise à jour : 17/06/06 L'objectif de cet article est d'expliquer certains principes des EJB 3 de Java EE 5 et

Plus en détail

INSTALLATION ET DEPLOIEMENT D ADOBE DIGITAL ENTERPRISE PLATFORM DOCUMENT SERVICES POUR JBOSS

INSTALLATION ET DEPLOIEMENT D ADOBE DIGITAL ENTERPRISE PLATFORM DOCUMENT SERVICES POUR JBOSS INSTALLATION ET DEPLOIEMENT D ADOBE DIGITAL ENTERPRISE PLATFORM DOCUMENT SERVICES POUR JBOSS Informations juridiques Informations juridiques Pour les informations juridiques, accédez à l adresse http://help.adobe.com/fr_fr/legalnotices/index.html.

Plus en détail

Installation esupdev2.5 environnement de test et prise en main d'esup-portail

Installation esupdev2.5 environnement de test et prise en main d'esup-portail Page 1 of 9 Installation esupdev2.5 environnement de test et prise en main d'esup-portail Ce document décrit comment installer et utiliser le package 'environnement de prise en main esupportail'. Vincent

Plus en détail

. 3 LES SERVEURS D'APPLICATIONS 24 -2-

. 3 LES SERVEURS D'APPLICATIONS 24 -2- Tout d'abord, je passe le majeur remerciement à, celui qui me donne tous les aides pour faire ce projet. Puis je donne mes remerciements à toutes les personnes qui me donnent la main-forte dans ce projet,

Plus en détail

2.1 Liferay en un clin d'oeil... 4 2.2 Forces, faiblesses, opportunités et menaces... 4 2.3 Résumé de notre évaluation... 5

2.1 Liferay en un clin d'oeil... 4 2.2 Forces, faiblesses, opportunités et menaces... 4 2.3 Résumé de notre évaluation... 5 Livre Blanc LE PORTAIL D'INTÉGRATION LIFERAY Version 1.0 - Novembre 2006 SOMMAIRE 1 PRÉSENTATION... 3 2 SYNTHÈSE... 4 2.1 Liferay en un clin d'oeil... 4 2.2 Forces, faiblesses, opportunités et menaces...

Plus en détail

Rapport de TER Application client-serveur de vente aux enchères

Rapport de TER Application client-serveur de vente aux enchères Rapport de TER Application client-serveur de vente aux enchères Dufourcq Matthieu Halot Sébastien Leman Pierre Melac Cyril Richardson Mikaël 2007-2008 REMERCIEMENTS Nous tenons à remercier M. Christophe

Plus en détail

Industrialisation des développements

Industrialisation des développements Industrialisation des développements NovaForge, l usine de développement logiciel de Bull Emmanuel Rias emmanuel.rias@bull.net 1 Agenda Introduction NovaForge Processus d un projet dans NovaForge et Fonctionnalités

Plus en détail

Installation personnalisée d'oracle 10g

Installation personnalisée d'oracle 10g Installation personnalisée d'oracle 10g Ressources Sachez avant tout que, comparativement à certains de ses concurrents, Oracle est extrêmement gourmand en ressources (mémoire et disque). Il est en effet

Plus en détail

Architecture N-Tier. Ces données peuvent être saisies interactivement via l interface ou lues depuis un disque. Application

Architecture N-Tier. Ces données peuvent être saisies interactivement via l interface ou lues depuis un disque. Application Architecture Multi-Tier Traditionnellement une application informatique est un programme exécutable sur une machine qui représente la logique de traitement des données manipulées par l application. Ces

Plus en détail

Pooling de connexions. Olivier Curé - UMLV [page 1 ]

Pooling de connexions. Olivier Curé - UMLV [page 1 ] Pooling de connexions Olivier Curé - UMLV [page 1 ] Introduction Une connexion à une base de données est une ressource rare et coûteuse qui ne peut être partagée par des threads. Il faut donc réfléchir

Plus en détail

Spring : tendances, nouveautés et perspectives

Spring : tendances, nouveautés et perspectives Spring : tendances, nouveautés et perspectives Paris JUG 13/11/2012 Arnaud Cogoluègnes Speaker Arnaud Cogoluègnes Consultant chez Zenika Formateur certifié SpringSource Co-auteur Spring Batch in Action

Plus en détail

Augmenter la disponibilité des applications JEE grâce au clustering : Le projet open source JShaft

Augmenter la disponibilité des applications JEE grâce au clustering : Le projet open source JShaft Augmenter la disponibilité des applications JEE grâce au clustering : Le projet open source Jérôme Petit, Serge Petit & Serli Informatique, ITMatic Jérôme Petit, Serge Petit & SERLI & ITMatic Serli : SSII

Plus en détail

Introduction à Eclipse

Introduction à Eclipse Introduction à Eclipse Eclipse IDE est un environnement de développement intégré libre (le terme Eclipse désigne également le projet correspondant, lancé par IBM) extensible, universel et polyvalent, permettant

Plus en détail

1-Introduction 2. 2-Installation de JBPM 3. 2-JBPM en action.7

1-Introduction 2. 2-Installation de JBPM 3. 2-JBPM en action.7 Sommaire 1-Introduction 2 1-1- BPM (Business Process Management)..2 1-2 J-Boss JBPM 2 2-Installation de JBPM 3 2-1 Architecture de JOBSS JBPM 3 2-2 Installation du moteur JBoss JBPM et le serveur d application

Plus en détail

Reporting Services - Administration

Reporting Services - Administration Reporting Services - Administration Comment administrer SQL Server Reporting Services Cet article a pour but de présenter comment gérer le serveur depuis le "portail" de Reporting Services. Nous verrons

Plus en détail

TP JEE Développement Web en Java. Dans ce TP nous commencerons la programmation JEE par le premier niveau d une application JEE : l application web.

TP JEE Développement Web en Java. Dans ce TP nous commencerons la programmation JEE par le premier niveau d une application JEE : l application web. ASTRIUM - Toulouse JEE Formation 2013 TP JEE Développement Web en Java Dans ce TP nous commencerons la programmation JEE par le premier niveau d une application JEE : l application web. Figure 1 Architecture

Plus en détail

IBM Rational Application Developer pour WebSphere Software V8.5 accélère le développement d'applications de haute qualité.

IBM Rational Application Developer pour WebSphere Software V8.5 accélère le développement d'applications de haute qualité. , datée du 24 avril 2012 IBM Rational Application Developer pour WebSphere Software V8.5 accélère le développement d'applications de haute qualité. Table des matières 1 Présentation 2 Date de disponibilité

Plus en détail

Hébergement de sites Web

Hébergement de sites Web Hébergement de Solutions complètes et évolutives pour l hébergement de sites Web dynamiques et de services Web sécurisés. Fonctionnalités Serveur Web Apache hautes performances Apache 1. et.0 1 avec prise

Plus en détail

CHAPITRE 1. Introduction aux web services. 1.1 Définition. Contenu du chapitre : Env. De dev. Langage Visual Studio Java EE Qt Creator C#

CHAPITRE 1. Introduction aux web services. 1.1 Définition. Contenu du chapitre : Env. De dev. Langage Visual Studio Java EE Qt Creator C# CHAPITRE 1 Introduction aux web services Contenu du chapitre : Env. De dev. Langage Visual Studio Java EE Qt Creator C# NetBeans JavaScript Eclipse Objective C Xcode PHP HTML Objectifs du chapitre : Ce

Plus en détail

DOSSIER DEVELOPPEUR Projet CAR

DOSSIER DEVELOPPEUR Projet CAR DOSSIER DEVELOPPEUR Projet CAR Maître d ouvrage (enseignant responsable) : Titulaire (équipe de conception) : William BOHER-COY Jonathan FAVIER Samuel ROLLET Robin HAIDER Date de rédaction : 26/01/2008

Plus en détail

Cours en ligne Développement Java pour le web

Cours en ligne Développement Java pour le web Cours en ligne Développement Java pour le web We TrainFrance info@wetrainfrance Programme général du cours Développement Java pour le web Module 1 - Programmation J2ee A) Bases de programmation Java Unité

Plus en détail