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: 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 :

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=" 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 :

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() + "@Remote"; 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:

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

Serveur 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é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

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

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

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

2 Chapitre 1 Introduction

2 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é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

MOTEUR DE WORKFLOW Mise en oeuvre d'openwfe Version 1.0-25 septembre 2006

MOTEUR DE WORKFLOW Mise en oeuvre d'openwfe Version 1.0-25 septembre 2006 MOTEUR DE WORKFLOW Mise en oeuvre d'openwfe Version 1.0-25 septembre 2006 SOMMAIRE 1 AVANT PROPOS...3 2 PRÉSENTATION...4 2.1 Quelques définitions...4 2.2 Besoins d'intégration d'un moteur de workflow...4

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

RMI le langage Java XII-1 JMF

RMI 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é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

TP réseau Android. Bidouilles Tomcat. a) Installer tomcat : il suffit de dézipper l'archive apache-tomcat-8.0.15-windowsx64.zip.

TP réseau Android. Bidouilles Tomcat. a) Installer tomcat : il suffit de dézipper l'archive apache-tomcat-8.0.15-windowsx64.zip. TP réseau Android Ce TP utilise tomcat 8, sous windows et des.bat windows. On peut trouver ce serveur web et conteneur d'applications web à http://tomcat.apache.org/download-80.cgi. Il se trouve dans l'archive

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

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

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

Microsoft OSQL OSQL ou l'outil de base pour gérer SQL Server

Microsoft OSQL OSQL ou l'outil de base pour gérer SQL Server Microsoft OSQL OSQL ou l'outil de base pour gérer SQL Server Suite à mon précédent article concernant MSDE, je me suis rendu compte à partir des commentaires que de nombreux utilisateurs avaient des problèmes

Plus en détail

Java DataBaseConnectivity

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

Alfstore workflow framework Spécification technique

Alfstore 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é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

TD/TP 1 Introduction au SDK d Android

TD/TP 1 Introduction au SDK d Android TD/TP 1 Introduction au SDK d Android Romain Raveaux 1 Introduction Android est un système d'exploitation pour téléphone portable de nouvelle génération développé par Google. Celui-ci met à disposition

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

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

MQPerf un outil de diagnostic en mode SaaS des performances optimales du MOM JORAM

MQPerf un outil de diagnostic en mode SaaS des performances optimales du MOM JORAM MQPerf un outil de diagnostic en mode SaaS des performances optimales du MOM JORAM Solutions Linux 20 juin 2012 Serge Lacourte Directeur Général serge.lacourte@scalagent.com www.scalagent.com Plan JORAM

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

Glassfish dans le milieu médical. Sun Aquarium Paris 26 Juin 2009 Jacky Renno (jacky.renno@capgemini.com)

Glassfish dans le milieu médical. Sun Aquarium Paris 26 Juin 2009 Jacky Renno (jacky.renno@capgemini.com) Glassfish dans le milieu médical Jacky Renno (jacky.renno@capgemini.com) Plan Contexte Métier Technique Eléments structurants Approche Méthodologie et Outillage Choix de Glassfish Automatisation Industrialisation

Plus en détail

TAGREROUT Seyf Allah TMRIM

TAGREROUT Seyf Allah TMRIM TAGREROUT Seyf Allah TMRIM Projet Isa server 2006 Installation et configuration d Isa d server 2006 : Installation d Isa Isa server 2006 Activation des Pings Ping NAT Redirection DNS Proxy (cache, visualisation

Plus en détail

Installation et prise en main

Installation et prise en main TP1 Installation et prise en main Android est le système d'exploitation pour smartphones, tablettes et autres appareils développé par Google. Pour permettre aux utilisateurs d'installer des applications

Plus en détail

Notre Catalogue des Formations IT / 2015

Notre Catalogue des Formations IT / 2015 Notre Catalogue des Formations IT / 2015 Id Intitulé Durée Gestion de projets et méthodes I1101 I1102 I1103 I1104 I1105 I1106 I1107 I1108 I1109 I1110 I1111 I1112 I1113 I1114 I1115 I1116 I1117 I1118 I1119

Plus en détail

JASMINe. Outils de gestion et supervision d'infrastructure intergicielle. Francois.Exertier@bull.net

JASMINe. Outils de gestion et supervision d'infrastructure intergicielle. Francois.Exertier@bull.net Outils de gestion et supervision d'infrastructure intergicielle Francois.Exertier@bull.net Agenda Introduction à Outil d'aide à la configuration Outil d'aide à la maintenance Outil d'aide à la supervision

Plus en détail

Whitepaper. Méthodologie de création de rapports personnalisés SQL Server Reporting Services

Whitepaper. Méthodologie de création de rapports personnalisés SQL Server Reporting Services Ce Whitepaper décrit la méthodologie de développement d un rapport personnalisé au format SQL Server Reporting Service (SSRS) appliqué à System Center Operations Manager (SCOM) Whitepaper Méthodologie

Plus en détail

Evidian IAM Suite 8.0 Identity Management

Evidian IAM Suite 8.0 Identity Management Evidian IAM Suite 8.0 Identity Management Un livre blanc Evidian Summary Evidian ID synchronization. Evidian User Provisioning. 2013 Evidian Les informations contenues dans ce document reflètent l'opinion

Plus en détail

7 villa de la citadelle Né le 13 mai 1983 94110 Arcueil Nationalité : Française. Développeur Web JEE COMPÉTENCES

7 villa de la citadelle Né le 13 mai 1983 94110 Arcueil Nationalité : Française. Développeur Web JEE COMPÉTENCES Philippe Crépin 7 villa de la citadelle Né le 13 mai 1983 94110 Arcueil Nationalité : Française : 06.17.46.12.09 : phi.crepin@gmail.com Disponibilité : En poste chez Soft Computing Développeur Web JEE

Plus en détail

I. Instalation de l environnement JDK et JRE :... 4. II. Configuration outil Reporting : Pentaho... 4

I. Instalation de l environnement JDK et JRE :... 4. II. Configuration outil Reporting : Pentaho... 4 Contenu I. Instalation de l environnement JDK et JRE :... 4 II. Configuration outil Reporting : Pentaho... 4 II.1 Configuration matérielle et logicielle... 4 II.2 Téléchargement et installation de la Suite

Plus en détail

OpenPaaS Le réseau social d'entreprise

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

et Groupe Eyrolles, 2006, ISBN : 2-212-11747-7

et Groupe Eyrolles, 2006, ISBN : 2-212-11747-7 Tsoft et Groupe Eyrolles, 2006, ISBN : 2-212-11747-7 OEM Console Java OEM Console HTTP OEM Database Control Oracle Net Manager 6 Module 6 : Oracle Enterprise Manager Objectifs Contenu A la fin de ce module,

Plus en détail

Projet 2. Gestion des services enseignants CENTRE D ENSEIGNEMENT ET DE RECHERCHE EN INFORMATIQUE. G r o u p e :

Projet 2. Gestion des services enseignants CENTRE D ENSEIGNEMENT ET DE RECHERCHE EN INFORMATIQUE. G r o u p e : CENTRE D ENSEIGNEMENT ET DE RECHERCHE EN INFORMATIQUE Projet 2 Gestion des services enseignants G r o u p e : B E L G H I T Y a s m i n e S A N C H E Z - D U B R O N T Y u r i f e r M O N T A Z E R S i

Plus en détail

Maarch V1.4 http://www.maarch.org

Maarch V1.4 http://www.maarch.org COLD (factures clients) Maarch Professional Services Maarch PS anime le développement d un produit d archivage open source : http://www.maarch.org Guide de visite COLD (factures clients) VERSION DATE ACTEUR

Plus en détail

Messagerie asynchrone et Services Web

Messagerie asynchrone et Services Web Article Messagerie asynchrone et Services Web 1 / 10 Messagerie asynchrone et Services Web SOAP, WSDL SONT DES STANDARDS EMERGEANT DES SERVICES WEB, LES IMPLEMENTATIONS DE CEUX-CI SONT ENCORE EN COURS

Plus en détail

D une part, elles ne peuvent faire table rase de la richesse contenue dans leur système d information.

D une part, elles ne peuvent faire table rase de la richesse contenue dans leur système d information. PACBASE «Interrogez le passé, il répondra présent.». Le Module e-business Les entreprises doivent aujourd hui relever un triple défi. D une part, elles ne peuvent faire table rase de la richesse contenue

Plus en détail

Oracle Database 11g: Administration Workshop I Release 2

Oracle Database 11g: Administration Workshop I Release 2 Oracle University Appelez-nous: +33 (0) 1 57 60 20 81 Oracle Database 11g: Administration Workshop I Release 2 Durée: 5 Jours Description Ce cours constitue la première étape de votre formation en tant

Plus en détail

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

Formation Webase 5. Formation Webase 5. Ses secrets, de l architecture MVC à l application Web. Adrien Grand <jpountz@via.ecp.fr> Centrale Réseaux Formation Webase 5 Ses secrets, de l architecture MVC à l application Web Adrien Grand Centrale Réseaux Sommaire 1 Obtenir des informations sur Webase 5 2 Composants de Webase 5 Un

Plus en détail

Cahier des charges : gestion de projets agiles. Programmation d Algorithmes Distribués (PAD)

Cahier des charges : gestion de projets agiles. Programmation d Algorithmes Distribués (PAD) Cahier des charges : gestion de projets agiles Programmation d Algorithmes Distribués (PAD) Benoit Bernardin Rachid Bouherrou Bruno Juillard Kaba Kabinè Sid-ahmed Anouar Lekhal 2012 / 2013 Sommaire I.

Plus en détail

Hibernate vs. le Cloud Computing

Hibernate vs. le Cloud Computing Hibernate vs. le Cloud Computing Qui suis-je? Julien Dubois Co-auteur de «Spring par la pratique» Ancien de SpringSource Directeur du consulting chez Ippon Technologies Suivez-moi sur Twitter : @juliendubois

Plus en détail

Pentaho. présentation

Pentaho. présentation Pentaho présentation Présentation Une solution BI Développé en java Lien de téléchargement: http://freefr.dl.sourceforge.net/project/pentaho/business%2 0Intelligence%20Server/4.8.0-stable/biserver-ce-4.8.0-

Plus en détail

Bases Java - Eclipse / Netbeans

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

KAJOUT WASSIM INTERNET INFORMATION SERVICES (IIS) 01/03/2013. Compte-rendu sur ISS KAJOUT Wassim

KAJOUT WASSIM INTERNET INFORMATION SERVICES (IIS) 01/03/2013. Compte-rendu sur ISS KAJOUT Wassim 01/03/2013 Le rôle de Serveur Web (IIS) dans Windows Server 2008 R2 vous permet de partager des informations avec des utilisateurs sur Internet, sur un intranet ou un extranet. Windows Server 2008 R2 met

Plus en détail

Formateurs : Jackie DAÖN Franck DUBOIS Médiapôle de Guyancourt

Formateurs : Jackie DAÖN Franck DUBOIS Médiapôle de Guyancourt Client sur un domaine stage personnes ressources réseau en établissement janvier 2004 Formateurs : Jackie DAÖN Franck DUBOIS Médiapôle de Guyancourt Lycée de Villaroy 2 rue Eugène Viollet Le Duc BP31 78041

Plus en détail

Network Shutdown Module V3 Extension du Manuel Utilisateur pour architecture Virtualisée VMWare ESX Server 3, 3.5

Network Shutdown Module V3 Extension du Manuel Utilisateur pour architecture Virtualisée VMWare ESX Server 3, 3.5 Network Shutdown Module V3 Extension du Manuel Utilisateur pour architecture Virtualisée VMWare ESX Server 3, 3.5 Machine virtuelle Machine virtuelle Machine virtuelle VMware ESX Network Shutdown Module

Plus en détail

Cours Master Recherche RI 7 Extraction et Intégration d'information du Web «Services Web»

Cours Master Recherche RI 7 Extraction et Intégration d'information du Web «Services Web» Cours Master Recherche RI 7 Extraction et Intégration d'information du Web «Services Web» Sana Sellami sana.sellami@lsis.org 2014-2015 Plan Partie 1: Introduction aux Services Web (SW) Partie 2: Vers une

Plus en détail

Préparation à l installation d Active Directory

Préparation à l installation d Active Directory Laboratoire 03 Étape 1 : Installation d Active Directory et du service DNS Noter que vous ne pourrez pas réaliser ce laboratoire sans avoir fait le précédent laboratoire. Avant de commencer, le professeur

Plus en détail

Analyse comparative entre différents outils de BI (Business Intelligence) :

Analyse comparative entre différents outils de BI (Business Intelligence) : Analyse comparative entre différents outils de BI (Business Intelligence) : Réalisé par: NAMIR YASSINE RAGUI ACHRAF Encadré par: PR. L. LAMRINI Dans le domaine d économies des Big Data et Open Data, comment

Plus en détail