J2EE. Java2 Enterprise Edition. Pierre Yves Gibello Mise à jour : 30 Septembre 2004
|
|
|
- Marcel Nolet
- il y a 10 ans
- Total affichages :
Transcription
1 J2EE Java2 Enterprise Edition Pierre Yves Gibello Mise à jour : 30 Septembre 2004 Ce document est couvert par la licence Creative Commons Attribution ShareAlike. This work is licensed under the Creative Commons Attribution ShareAlike License.
2 J2EE Objectifs Faciliter le développement de nouvelles applications à base de composants Intégration avec les systèmes d information existants Support pour les applications «critiques» de l entreprise Disponibilité, tolérance aux pannes, montée en charge, securité...
3 J2EE C est quoi? Spécifications Modèle de programmation Implémentation de référence Suite(s) de tests Label J2EE Sun (qualification de plateformes)
4 Offre commerciale BEA WebLogic (haut de gamme) IBM Websphere (no 1) Sun Java System App. Server Borland Enterprise Server Oracle 9i Application Server Macromedia jrun SAP Web application server Iona Orbix E2A
5 Offre open source JBoss (no 1 en nombre de déploiements) ObjectWeb JOnAS(no 2, intégré à plusieurs distro Linux Entreprise) Apache Geronimo (démarrage fin 2003) openejb ejbean
6 J2EE sous l œil de Darwin... Standard en évolution depuis 1997 J2EE 1.0 à 1.4 en 2003, etc... Au départ, applications Web n tiers Présentation (Servlets puis JSP), essentiellement HTTP Logique métier : EJB Données : JDBC Puis infrastructure de support standard pour EAI Facteurs de rationnalisation majeurs (JTA, JMS, JCA, Web Services) Evolution de progiciels existants vers J2EE
7 J2EE Architecture Browser WEB Container html http Servlets JSPs JDBC JMS JTA Applets rmi rmi JCA JAAS DB rmi EJBs JavaMail JNDI public static void main( ) { EJB Container EIS Java Application J2EE Application Server
8 Client Architecture multi tiers Léger (Web, browser) Lourd (Application java, Applet ) Architecture orientée service (Application répartie sans présentation) Serveur d applications Conteneur EJB + logique métier Services non fonctionnels EIS ou Base de données
9 Un serveur J2EE Java Client Source : Bull/ObjectWeb (JOnAS) RMI Calls JOnAS «J2EE» Server Web Container EJB Container HTTP Servlets Home interface Remote interface Enterprise Enterprise Enterprise Java Bean Java Bean Java Bean HTML Client Web Transaction Management Ear Naming EJB Database... JDBC Calls database Services
10 Conteneur Web Servlets Code java exécuté sur le serveur Equivalent du CGI Génération de contenu Web dynamique JSP: Java Server Pages Mélange de HTML/XML et de code java Librairies d extension («taglibs») Précompilation en servlet
11 RMI Remote Method Invocation Java seulement, mais passerelles «RPC objet» (appels sur objets distants) Service de nommage (RMI registry) Sécurité paramétrable (SecurityManager) Garbage Collection distribuée Téléchargement de code Fonctions avancées Activation d objets persistents, Réplication
12 JNDI Service de nommage / annuaire Java Naming and Directory Interface API accès aux annuaires javax.naming «Service Provider» par annuaire cible (LDAP, NIS, RMI registry ) Utilisation avec les EJB Accès à l interface «home» pour initialiser Accès à diverses ressources (UserTransaction, Queues JMS, DataSources )
13 JMS Java Messaging Service JMS Provider : inclus dans J2EE Transport synchrone ou asynchrone, Garantie de livraison «Messaging domains» point à point ou «publish/subscribe» Lien avec EJB : «message driven bean» Pour échanges asynchrones
14 API J2EE de transactions : JTA Java Transaction API Package javax.transaction TransactionManager : begin(), commit(), rollback() Transaction : commit(), rollback(), enlistresource(xaresource), registersynchronisation(synchronization)... Synchronization : beforecompletion(), aftercompletion(commit rollback)
15 JTA : Participants XAResource Conformes à la spécification XA Enregistment avec transaction.enlistresource() Synchronization Pour les ressources «non transactionnelles» (EAI ) Participant averti des frontières de transaction enregistrement : transaction.registersynchronization() beforecompletion() équivaut à prepare() aftercompletion(état = commit rollback) équivaut à commit rollback
16 API XA de J2EE Package javax.transaction.xa XAResource (prepare(), commit(), rollback()... Xid (identifiant de transaction XA) Package javax.sql Extension de JDBC (bases de données) XADataSource (getxaconnection()) XAConnection (PooledConnection, avec getconnection() et getxaresource())
17 JMX Java Management extensions API unique pour applications de management Mbeans avec accesseurs get/set Typage faible, attributs nommés Serveur JMX Enregistrement des Mbeans Les applis d administration dialoguent avec le serveur JMX Instrumenter un composant Fournir un ou des Mbeans Les enregistrer auprès du serveur JMX
18 JMX : Exemple d un serveur J2EE Source : ObjectWeb JOnAS Admin console EJB Container EJBs WEB Container Admin Servlets MBeans Registry EJB Transaction Security EAR Web.. Management JMX Server MC4J Services J2EE Server
19 EJB: Architecture JavaBeans pour l Enterprise Pas des JavaBeans (pas de représentation graphique) Logique métier S appuie sur J2SE et les APIs de J2EE JNDI, JTA/JTS, JDBC, JMS, JAAS Gestion déclarative (personnalisation sans toucher au code source) Portable sur les différents conteneurs EJB
20 EJB: Gamme de services implicites Gestion du cycle de vie Gestion de l état Sécurité Transactions Persistance Localisation des composants transparente (comparable à objets distribués CORBA) Répartition de charge, pooling => Le développeur se focalise sur les aspects métier
21 Lifecycle interface create remove find Remote(rmi) ou Local Implementé par le conteneur Client Interface Métier: Remote(rmi) ou local EJB Implementation du composant: logique métier (code) callbacks pour le conteneur (ejbcreate, ejbpassivate, ejbload, ) Home Composant Descripteur de déploiement: comportement transactionnel (Tx attributes) Sécurité (ACLs) Persistance (entity beans) Ressources (DataSources ) Logique métier + Callbacks + ic=new InitialContext(); ds = (DataSource) ic.lookup( java:comp/env/jdbc/myds ); DD <resource ref> <..name>jdbc/myds <trans attribute>required Conteneur EJB
22 EJB: Interface composant Remote (RMI) ou Local Vue client de l EJB Declare les méthodes métier Implementée par les outils intégrés à la plateforme EJB au moment du déploiement
23 Exemple: Remote Interface javax.ejb.ejbobject Hérite de Interface Fournisseur // méthodes métier + getnom():nom + setnom(nom:nom):void + getadresse():adresse + setadresse( adresse:adresse):void
24 EJB: Home Interface Interface composant accessible à distance (RMI) Représente le cycle de vie du composant (création, suppression, recherche) Implementée par les outils intégrés à la plateforme EJB Séparée de la Remote Interface car elle représente des comportements non spécifiques à une instance de bean
25 Exemple: Home Interface javax.ejb.ejbhome Hérite de Interface FournisseurHome // méthodes de gestion de cycle de vie + create(id:integer):fournisseur + findbyprimarykey( id:integer):fournisseur
26 EJB: Implémentation du Bean Hérite de EntityBean ou SessionBean mais n implémente pas les interfaces Home ou Remote Pourtant: Implémente les méthodes métier de l interface Remote Définit et déclare les methodes correspondant à l interface Home.
27 Exemple : Implém. de Bean javax.ejb.entitybean Interface Implémente Class FournisseurBean id:int nom:nom adresse:adresse // méthodes de gestion de cycle de vie + ejbcreate( id:integer):void + ejbfindbyprimarykey( id:integer):void // méthodes métier + getnom():nom + setnom( nom:nom):void + getadresse():adresse + setadresse( adresse:adresse):void
28 EJB: Code client Object ref ; FournisseurHome home; // Home interface Fournisseur fourn; // Remote interface, pas le bean // appel JNDI pour obtenir une référence à l interface Home ref = jndicontext.lookup( "java:comp/env/ejb/fournisseur"); home = PortableRemoteObject.narrow(ref, FournisseurHome.class); // créer un Bean fourn = home.create(idfournisseur); // appel méthode métier fourn.setnom(unnom);
29 EJB: Bean Entité Représente des données dans la base de données Container Managed Persistence (CMP) or Bean Managed Persistence (BMP) En mode CMP, le conteneur EJB gère la persistance du bean (pas d accès BD dans le code). En mode BMP, c est le développeur du Bean qui gère la persistance (par exemple, en JDBC).
30 EJB: Bean Session Gestion des interactions entre beans entité ou session, accès aux ressources, réalisation d actions sur demande du client Objets métier non persistants Stateful ou Stateless maintient ou pas un état interne en mémoire => Un Bean Stateful encapsule la logique métier et l état specifiques à un client
31 EJB : Message Driven Bean Composant asynchrone Execution sur réception d un message JMS Méthode onmessage() Appels à d autres beans, etc Descripteur de déploiement Associations Bean / ressource JMS Ressources JMS (ex. Queue ou Topic)
32 Message Driven Bean : exemple TX MDB StockHandler Mise à jour Entity Bean Stock BD Envoi message MDB Order Appli : Client JMS publier Serveur EJB JMS Topic Queue QCF créer créer Administration bind JNDI
33 Message Driven Bean : exemple (2) public class StockHandlerBean implements MessageDrivenBean, MessageListener { public void onmessage(message message) {... sh = (StockHome)initialContext.lookup("java:comp/env/ejb/Stock"); queue = (Queue)initialContext.lookup("java:comp/env/jms/Orders"); MapMessage msg = (MapMessage)message; pid = msg.getstring("productid"); qty = msg.getstring( "Quantity"); cid = msg.getstring("customerid"); Stock stock = sh.findbyprimarykey(pid); stock.decreasequantity(qty); qs = session.createsender(queue); TextMessage tm = session.createtextmessage(); String m = "For CustomerId = "+cid+" ProductId= "+pid+" Quantity= "+qty; tm.settext(m); qs.send(tm);... } }
34 EJB: Configuration & Déploiement Interfaces Home et Remote (ou Local), classe qui implémente le Bean Descripteur de déploiement (fichier XML) <ejb jar> Description du Bean (Entity ou Session,...) Ressources (Base de données,...) Securité: permissions et roles Persistance (BMP, CMP) Attributs transactionnels </ejb jar> => Utilisé par l assembleur d application et par le conteneur EJB au moment du déploiement
35 Descripteur de déploiement : Bean <enterprise beans> <entity> <description>ejb Fournisseur ( BMP )</description> <ejb name>fournisseur</ejb name> <home>logistique.fournisseurhome</home> <remote>logistique.fournisseur</remote> <ejb class>logistique.fournisseurbean</ejb class> <persistence type>bean</persistence type> <prim key class>java.lang.string</prim key class> <reentrant>false</reentrant> <resource ref> <res ref name>jdbc/clientdb</res ref name> <res type>javax.sql.datasource</res type> <res auth>container</res auth> </resource ref> </entity> </enterprise beans> Bean Entité Ressource : ici, BD «Indirection» : Lien entre interfaces et implémentation Persistance : Bean ou Container
36 Ressources et JNDI Ressources déclarées dans le descripteur de déploiement (accès via JNDI) Convention de nommage Noms préfixés par le type de ressource référencée (ejb, jms, jdbc, mail, url ) Exemple fh = (FournisseurHome)initialContext.lookup( "java:comp/env/ejb/fournisseur"); bd = (DataSource)initialContext.lookup( "java:comp/env/jdbc/compta");
37 Indirection Contrat du conteneur entre les clients et les EJB Garantit que l on passe par le conteneur Exemple : activation / passivation, pool d instances... La classe d implémentation n implémente pas les interfaces Home ou Remote; pourtant, elle implémente les méthodes de Home et Remote Le lien est fait par le descripteur de déploiement Renommage des méthodes de Home create() > ejbcreate(), etc... Exception si appel direct! (méthode inexistante)
38 Indirection : implémentations Génération de code (JOnAS, WebLogic) Code d interposition entre le bean et le conteneur Généré à partir des interfaces du bean Paramétré par le descripteur de déploiement Dynamic Proxy (JBoss) Pas de génération / compilation Plus souple, mais moins efficace
39 Optimisations liées à l indirection Stateless Session Bean : Sans état Pool d instances Le serveur peut y accéder via un pool de threads Stateful session et Entity beans Activation / Passivation (appel par le container de ejbactivate() après activation / ejbpassivate() avant passivation)
40 Conséquences de l indirection... Attention à «this»... Pas de «this.methode()» sur les méthodes d interfaces «local» ou «remote» Eviter de passer «this» en paramètre Utiliser les références! Remote : context.getejbobject() Local : context.getejblocalobject() Contexte initialisé par le conteneur appel setsessioncontext ou setentitycontext après la création (méthode à implémenter).
41 Descripteur de déploiement : Persistance Bean managed (BMP) <persistence type>bean</persistence type> Container managed (CMP) <persistence type>container</persistence type> <cmp field> <field name>codefournisseur</field name> </cmp field>
42 Persistance BMP Bean managed persistence Le bean gère sa persistance Exemple : usage direct de JDBC Appels de méthodes par le conteneur ejbload() restaurer l état ejbstore() sauvegarder l état Méthodes jamais appelées par le Bean! (ne pas appeler depuis activate / passivate)
43 Persistance CMP Persistance gérée par le conteneur Gestion déclarative (descripteur de déploiement) Champs persistants (avec méthodes get/set) Relations entre instances d entités CMP (CMP2) (cardinalité 1 1 ou 1 N, uni ou bi directionnel) EJB QL (CMP2) Basé sur SQL92 («select from where») Méthodes «find» associées à des requêtes avec paramètres
44 Exemple CMP: Home interface public interface BookHome extends EJBHome { public Book create(string id, String author) throws RemoteException, CreateException; public Book findbyprimarykey (String id) throws RemoteException, FinderException; } public Collection findbyauthor(string author) throws RemoteException, FinderException;
45 CMP: Descripteur de déploiement <entity> <display name>book</display name> <ejb name>book</ejb name> <home>bookhome</home> <remote>book</remote> <ejb class>bookejb</ejb class> <persistence type>container</persistence type> <prim key class>java.lang.string</prim key class> <cmp field><field name>title</field name></cmp field> <cmp field><field name>author</field name></cmp field> <cmp field><field name>price</field name></cmp field> <primkey field>title</primkey field> <query> <description></description> <query method> <method name>findbyauthor</method name> <method params> <method param>java.lang.string</method param> </method params> </query method> <ejb ql>select distinct object(b) from Book b where b.author=?1</ejb ql> </query> </entity> Inutile d implémenter la méthode findbyauthor()
46 CMP: Méthodes find et ejbselect «Finder methods» (findby ) Retournent 1 bean (interface métier) ou une Collection Méthodes ejbselect Equivalent aux «findby» Local à un bean (pas d accès externe)
47 Transactions Applicable aux 3 profils de composants Session, Entité, Message driven Limitation pour le MessageDriven (attributs «Required» ou «NotSupported» seulement). Gestion explicite Utilisation de javax.transaction.usertransaction (JTA) Contrôle de la transaction (timeout, «rollbackonly») Exemple UserTransaction utx = (UserTransaction)ctx.lookup(«java:comp/UserTransaction»); utx.begin(); utx.commit();
48 Descripteur de déploiement : Gestion déclarative des Transactions <assembly descriptor> <container transaction> <method> <ejb name>fournisseur</ejb name> <method name>*</method name> </method> <trans attribute>required</trans attribute> </container transaction>... </assembly descriptor> NotSupported Required RequiresNew Mandatory Supports Never
49 Gestion déclarative des transactions Au niveau de la méthode du bean! (démarcation) NotSupported Si transaction courante, elle est suspendue Required Si pas de transaction, nouvelle transaction RequiresNew Nouvelle transaction (si tx courante, suspendue) Mandatory Exception si pas de transaction courante Supports Si transaction courante, l utiliser Never Exception si transaction courante
50 Gestion des évènements transactionnels (Session Bean) Interception par un EJB des évènements transactionnels (produits par le conteneur) Implantation de javax.ejb.sessionsynchronization Evènements (appelés par le conteneur) afterbegin : appelé après UserTransaction.begin beforecompletion : appelé avant UserTransaction.commit aftercompletion(true false) : appelé après commit ou rollback
51 Descripteur de déploiement : <assembly descriptor>... <security role> Sécurité <description>personnel administratif de gestion</description> <role name>administratif</role name> </security role> <method permission> <role name>administratif</role name> <method> <ejb name>fournisseur</ejb name> <method name>*</method name> </method> </method permission> </ assembly descriptor> Définition de rôle Permissions accordées à un rôle
52 JCA Java Connector Architecture Intégration avec les SI d entreprise (EIS) Applications (ERP, Supply Chain ) Middleware (gestionnaire de transactions ) Connecteur composé de : Contrats système API cliente Resource Adapter
53 Contrats Système Interaction entre le SI et le serveur d applications Gestion des connexions et pooling Gestion des transactions (par le serveur d application et/ou le SI) Sécurité (accès sécurisé au SI)
54 API clientes Standard : CCI (Common Client Interface) Avantage : API standard Inconvénient : trop général et peu compréhensible (pas de «sens» métier), implémentation facultative. Spécifique : API spécifique au SI, fournie par le «resource adapter» Avantage : API «métier» Inconvénient : spécifique au SI concerné, donc différente selon le connecteur...
55 Resource Adapter Implémentation de l interfaçage avec le SI Classes d interface Librairies natives du SI Descripteur de déploiement Configuration du connecteur au sein du serveur d application Classes d implémentation des interfaces standard Fonctionnalités supportées ou non (transactions, sécurité )
56 Déploiement Packaging en fichier.rar (RA archive) Déployé par le serveur d application Format jar avec organisation standard Contient tous les éléments du connecteur Descripteur de déploiement (ra.xml) dans META INF : configuration du connecteur
57 Rôles définis par la spec. EJB Fournisseur de beans Développeur qui crée les EJB Assembleur d application Crée l application par assemblage d EJB Administrateur Déploiement, sécurité, explotation, montée en charge Analogue au rôle de DBA pour les BD
58 Packaging Application J2EE (aggrégarion de différents tiers) Fichier «.ear» + descripteur «application.xml» Tiers client Web : fichier «.war» + descripteur «web.xml» Application : fichier «.jar» + descripteur «application client.xml» (lancement du main() de la classe spécifiée dans le «manifest», attribut «Main Class») Tiers EJB Fichier «.jar» + descripteur «ejb jar.xml» Tiers «EIS» (connecteurs JCA) Fichier «.rar» + descripteur «rar.xml»
59 Persistance + Transactions : exemple Conteneur EJB EB1 DD no cust DB1 DB2 EJB JMX REG DBM R1 server2 Admin client http Conteneur WEB admin SrVlt Conteneur EJB EB2 Web JMX 2 phase commit JTM JMX EJB DBM R2 Appli client server1 server3
60 Répartition de charge : notations Un noeud (machine) qui héberge un ou plusieurs serveurs web Un conteneur Web ejb Un conteneur EJB web Un serveur qui héberge un conteneur Web ejb Un serveur qui héberge un conteneur EJB web ejb Un serveur qui héberge un conteneur Web et un conteneur EJB Apache mod_jk Un serveur Apache avec le module mod_jk
61 Répartition de charge : scenarii (1) Répartition du serveur J2EE Compact Réparti (au sein d un même nœud) Réparti web ejb web ejb web ejb
62 Répartition de charge : scenarii (2) (1) (2) web ejb web ejb Apache mod_jk Apache mod_jk web ejb web ejb (3) Répartition de charge EJB Réplication session http (4) web web ejb Apache mod_jk ejb Apache mod_jk web web ejb
63 Répartition de charge et clustering Source : ObjectWeb JOnAS Tomcat JOnAS EJB Container JNDI Apache Mod_jk Tomcat Tomcat JOnAS EJB Container JOnAS EJB Container JNDI JNDI DB
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
Java EE. Java Enterprise Edition. Pierre-Yves Gibello - [email protected] (Mise à jour : Septembre 2011)
Java EE Java Enterprise Edition Pierre-Yves Gibello - [email protected] (Mise à jour : Septembre 2011) Ce document est couvert par la licence Creative Commons Attribution-ShareAlike. This
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é[email protected]
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
Composants logiciels Exemples : Java Beans, Enterprise Java Beans
Composants logiciels Exemples : Java Beans, Enterprise Java Beans Sacha Krakowiak Université Joseph Fourier Projet Sardes (INRIA et IMAG-LSR) http://sardes.inrialpes.fr/~krakowia Introduction : évolution
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
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
Introduction à la plateforme J2EE
Introduction à la plateforme J2EE Auteur : Oussama Essefi Directeur technique Expert Consulting [email protected] Copyright 2010 Expert Consulting Page 1 1. Introduction 1.1. Pourquoi
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
Plan. Department of Informatics
Plan 1. Application Servers 2. Servlets, JSP, JDBC 3. J2EE: Vue d ensemble 4. Distributed Programming 5. Enterprise JavaBeans 6. Enterprise JavaBeans: Special Topics 7. Prise de recul critique Enterprise
Applications des patrons de conception
MAI NFE103 Année 2013-2014 Applications des patrons de conception F.-Y. Villemin, CNAM! http://deptinfo.cnam.fr/enseignement/cyclespecialisation/mai/index.html Plan! Java Beans*! Patron "Modèle-vue-contrôleur"
Projet. But: consultation en temps réel d événements (cours de bourse, trafic d envoi SMS ) sur des téléphones portables. Serveur de diffusion
Projet But: consultation en temps réel d événements (cours de bourse, trafic d envoi SMS ) sur des téléphones portables événements Serveur de diffusion 1 JMS Java Message Service PHAN Quang-Hai ISTR 04/05/2004
Environnements de Développement
Institut Supérieur des Etudes Technologiques de Mahdia Unité d Enseignement: Environnements de Développement BEN ABDELJELIL HASSINE Mouna [email protected] Développement des systèmes d Information Syllabus
Java Naming and Directory Interface
Introduction Java Naming and Directory Interface Gaël Thomas [email protected] Université Pierre et Marie Curie Master Informatique M2 Spécialité SAR Java Naming and Directory Interface (JNDI) Java Standard
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 ([email protected]), UNSA 2002, modifié par Richard Grin (version 1.1, 21/11/11), avec emprunts aux supports de Maxime
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:...
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
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
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
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
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
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
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.
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
10. Base de données et Web. OlivierCuré [[email protected]]
10. Base de données et Web 313 Evolution de l'information Ordre de grandeur : 314 1Mo : 1 gros roman 200Mo : ce que mémorise un être humain dans sa vie. 900Mo : information contenue dans le génome d'une
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
C-JDBC. Emmanuel Cecchet INRIA, Projet Sardes. http://sardes.inrialpes.fr
Emmanuel Cecchet INRIA, Projet Sardes http://sardes.inrialpes.fr Plan Motivations Idées principales Concepts Caching Perspectives /ObjectWeb 15 octobre 2002 [email protected] 2 - Motivations
Java Enterprise Edition
Java Enterprise Edition Malik SAHEB [email protected], [email protected] Course Objectives Understanding the value propositions of Java EE Getting a big picture of Java EE architecture and platform Getting
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é
IBM WebSphere Application Server 5.0 : Administration avancée
IBM WebSphere Application Server 5.0 : Administration avancée Slim CHENNOUFI Karim JENZRI [email protected] [email protected] INSAT GL5 2004/2005 WAS 5.0: Pratiques d Administration 1 Plan La plate-forme
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
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
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
Ré-architecture et migration d une application standalone vers un serveur applicatif multi-tiers dans un contexte JAVA-SAP
Ré-architecture et migration d une application standalone vers un serveur applicatif multi-tiers dans un contexte JAVA-SAP Ionel Dembski Sous la direction de Peter Daehne, Professeur HES Département d
Remote Method Invocation (RMI)
Remote Method Invocation (RMI) TP Réseau Université Paul Sabatier Master Informatique 1 ère Année Année 2006/2007 Plan Objectifs et Inconvénients de RMI Fonctionnement Définitions Architecture et principe
Présentation J2EE. Stéphane Croisier, Directeur Serge Huber, Directeur Technique. 13 Juin 2002. 2002 Jahia Ltd. All rights reserved.
Présentation J2EE Stéphane Croisier, Directeur Serge Huber, Directeur Technique 13 Juin 2002 Table des Matières Qui sommes-nous? Introduction J2EE Architecture J2EE Avantages / Désavantages Le Projet Jahia
Le passage à l échelle de serveur J2EE : le cas des EJB
Le passage à l échelle de serveur J2EE : le cas des EJB Sylvain Sicard, Noël De Palma, Daniel Hagimont CFSE 4 5-8 Avril 2005 LSR 1 Plan de la présentation 1. Architecture de serveur J2EE en grappe 2. Problématique
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
Composants Logiciels. Le modèle de composant de CORBA. Plan
Composants Logiciels Christian Pérez Le modèle de composant de CORBA Année 2010-11 1 Plan Un rapide tour d horizon de CORBA 2 Introduction au modèle de composant de CORBA Définition de composants CORBA
Module BD et sites WEB
Module BD et sites WEB Cours 8 Bases de données et Web Anne Doucet [email protected] 1 Le Web Architecture Architectures Web Client/serveur 3-tiers Serveurs d applications Web et BD Couplage HTML-BD
Modèle d Administration des Systèmes Distribués à Base de Composants.
Institut National des Sciences Appliquées de Lyon THESE Pour obtenir le grade de Docteur de l Institut National des Sciences Appliquées de Lyon Préparée au laboratoire : CITI Dans le cadre du projet :
Nouvelles Plateformes Technologiques
Cycle de présentation du développement Nouvelles Plateformes Technologiques Observatoire Technologique, CTI Observatoire Technologique 4 mai 2004 p 1 Plan de la présentation 1. Historique du projet 2.
Architecture applicative et Cartographie
Architecture applicative et Cartographie Mineure SOA Idir AIT SADOUNE [email protected] Programme 7 nov. 14 nov. 21 nov. Introduction. Enjeux, rôle de l'architecte SI Partie n 1 du cas d'étude
Les processus métiers : concepts, modèles et systèmes
Les processus métiers : concepts, modèles et systèmes Organisation du cours Concepts et notations Modélisation des processus Systèmes de gestion de processus Processus transactionnels Découverte de processus
Apache Tomcat 6. Guide d'administration du serveur Java EE sous Windows et Linux. Résumé. Étienne LANGLET
Apache Tomcat 6 Guide d'administration du serveur Java EE sous Windows et Linux Étienne LANGLET Résumé Ce livre sur Apache Tomcat 6 s adresse à toute personne appelée à mettre en oeuvre ce serveur sous
TD sur JMS ---- 1) Qu est-ce qu un middleware orienté message (MOM)? Quelles différences faites-vous entre un MOM et JMS?
TD sur JMS ---- Questions de cours : 1) Qu est-ce qu un middleware orienté message (MOM)? Quelles différences faites-vous entre un MOM et JMS? MOM : Message Oriented Middleware Intergiciels orientés Messages
NSY102. Conception de logiciels Intranet Introduction
Conception de logiciels Intranet Introduction Cnam Paris jean-michel Douin, douin au cnam point fr 6 Février 2009 Une Introduction 1 Sommaire Introduction Généralités Tendances historique API & Intergiciel
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
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
Evaluation Idéopass Cahier d analyse technique
Evaluation Idéopass Cahier d analyse technique Version 1 GMSIH 374, rue de Vaugirard 75015 Paris. Tel : 01 48 56 72 70. Fax : 01 48 56 07 70 Auteur(s) du document : Contrôle Qualité GMSIH Date : 17/03/2005
Urbanisme du Système d Information et EAI
Urbanisme du Système d Information et EAI 1 Sommaire Les besoins des entreprises Élément de solution : l urbanisme EAI : des outils au service de l urbanisme 2 Les besoins des entreprises 3 Le constat
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
Systèmes répartis. Fabrice Rossi http://apiacoa.org/contact.html. Université Paris-IX Dauphine. Systèmes répartis p.1/49
Systèmes répartis Fabrice Rossi http://apiacoa.org/contact.html. Université Paris-IX Dauphine Systèmes répartis p.1/49 Systèmes répartis Définition très large : un système réparti est système informatique
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
Architectures n-tiers Intergiciels à objets et services web
Plan pour aujourd hui Architectures n-tiers Intergiciels à objets et services web Clémentine Nebut Nebut LIRMM / Université de Montpellier 2 [email protected] Introduction Architectures classiques
Réalisation : Encadrés par : BEN GHORBEL Mohamed Zied OUESLATI Cherif. Mr. ROMDHANI Mohamed
Réalisation : BEN GHORBEL Mohamed Zied OUESLATI Cherif Encadrés par : Mr. ROMDHANI Mohamed Plan Le projet JBoss JBoss : La Naissance JBoss : un serveur d application libre JBoss : Un serveur certifié J2EE
Java - RMI Remote Method Invocation. Java - RMI
Remote Method Invocation Yann Viémont Université de Versailles St-Quentin Plan 1. Introduction 2. Rappels sur les RPC 3. Le modèle objet de Java-RMI 4. Architecture générale 1. Introduction = Disponible
IBM DB2 Alphablox. d administration GC11-2170-00
IBM DB2 Alphablox Guide d administration Version 8.4 GC11-2170-00 IBM DB2 Alphablox Guide d administration Version 8.4 GC11-2170-00 ii IBM DB2 Alphablox - Guide d administration Table des matières Avis
Programme «Analyste Programmeur» Diplôme d état : «Développeur Informatique» Homologué au niveau III (Bac+2) (JO N 176 du 1 août 2003) (34 semaines)
Programme «Analyste Programmeur» Diplôme d état : «Développeur Informatique» Homologué au niveau III (Bac+2) (JO N 176 du 1 août 2003) (34 semaines) Module 1 : Programmer une application informatique Durée
BMC Middleware Management
BMC Middleware Management Réunion GUIDE Share France WMQ 2 octobre 2012 Didier Hauwy Software Consultant [email protected] Sommaire Middleware Monitoring - MainView for WMQ - BMM Performance & Availability
Développement, déploiement et sécurisation d'applications JEE
JBoss Développement, déploiement et sécurisation d'applications JEE Franck SIMON Résumé Ce livre sur JBoss s'adresse aux développeurs Java quotidiennement confrontés au développement et au déploiement
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
Conception et Implémentation d un serveur d applications dans le cadre du projet EISMO
L Y O N MASTERE SPECIALISE EN INFORMATIQUE Année 2003/2004 Conception et Implémentation d un serveur d applications dans le cadre du projet EISMO Par Pierre-Henri FONTANAUD Soutenu le 23 Novembre 2004
Jahia. Guillaume Monnette École Ingénieurs 2000 Marne-La-Vallée IR3
Jahia Guillaume Monnette École Ingénieurs 2000 Marne-La-Vallée IR3 Qu'est ce que c'est? Jahia est une solution de portail internet et de gestion de contenu destiné aux entreprises. (CMS and Enterprise
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
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
Catalogue des Formations Techniques
Catalogue des Formations Techniques Items Média Concept 4, allées Pierre-Gilles de Gennes - 33700 Mérignac Téléphone : 05.57.35.73.73 Télécopie : 05.57.35.73.70 Courriel : [email protected] 2 Préambule
Utilisation de Jakarta Tomcat
ISI 1022 : Déploiement d applications Web Jean-Noël Sorenti. Année 2002/2003 Déploiement d application Web Utilisation de Jakarta Tomcat ISI 1022 : 1 ISI 1022 : Déploiement d applications Web Une application
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)
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
Utilisation de JAVA coté Application serveur couplé avec Oracle Forms Hafed Benteftifa www.degenio.com Novembre 2008
Introduction Utilisation de JAVA coté Application serveur couplé avec Oracle Forms Hafed Benteftifa www.degenio.com Novembre 2008 Forms 10g permet l utilisation du JAVA côté client et côté application
EJB. Karim Bouzoubaa Issam Kabbaj
EJB Karim Bouzoubaa Issam Kabbaj Problématique html jsp Objets java jdbc table Pour accéder aux données : Établir une connexion avec la BD Envoyer une requête Traiter la requête Assurer l'intégrité Or
NFP111 Systèmes et Applications Réparties
NFP111 Systèmes et Applications Réparties 1 de 34 NFP111 Systèmes et Applications Réparties Cours 7 - CORBA/Partie 1 Claude Duvallet Université du Havre UFR Sciences et Techniques 25 rue Philippe Lebon
Windows (2000/NT), Solaris, AIX, HP-UX, Linux Haute disponibilité : SunCluster 3, Veritas Cluster Server 4. J2EE (JSP, Servlet, EJB, JTA), Open Source
David MAFFRAND Architecte SI E-mail : [email protected] Web : http://dmaf.free.fr Certifié Weblogic Server 6 Certifié webmethods Integration 4.6 Certifié webmethods Enterprise 5.0 Certifié webmethods
Introduction aux «Services Web»
Introduction aux «Services Web» Sana Sellami [email protected] 2014-2015 Modalité de contrôle de connaissances Note de contrôle de continu Note projet Evaluation du projet la semaine du 17 novembre
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 [email protected] www.scalagent.com Plan JORAM
Java et les bases de données: JDBC: Java DataBase Connectivity SQLJ: Embedded SQL in Java. Michel Bonjour http://cuiwww.unige.
: JDBC: Java DataBase Connectivity SQLJ: Embedded SQL in Java Michel Bonjour http://cuiwww.unige.ch/~bonjour Plan JDBC: API bas niveau pour l accès aux BD (SQL) - Introduction - JDBC et : Java, ODBC, SQL
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
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
Notes de version de Sun Java System Application Server Enterprise Edition
Notes de version de Sun Java System Application Server Enterprise Edition Version 8.1 2005T1 Référence 819-2025 Sun Java System Application Server Enterprise Edition 8.1 2005T1 simplifie considérablement
Datalift. + + Architecture Modularité Déploiements. d j = 09/04/2015 Laurent BIHANIC
lift 1 d j = ( + + Architecture Modularité Déploiements lift 2 plates-formes en 1 2 Se t Se Dat t Une architecture répondant à deux besoins : Elévation de la donnée Exploitation de la donnée publiée Des
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
Projet Java EE Approfondi
EISTI Projet Java EE Approfondi Manuel d installation du framework Stripes Amaury Languillat, Yann Gonzalez, Arnaud Recher, Vincent Laronde, Anys Mechkar 10 Manuel d installation Téléchargement On part
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
Extension SSO Java. Cette note technique décrit la configuration et la mise en œuvre du filtre de custom SSO Java.
Note technique W4 Engine Extension SSO Java Cette note technique décrit la configuration et la mise en œuvre du filtre de custom SSO Java. 1 Présentation 3 2 Custom SSO Java 4 3 Bilan 10 Sommaire Référence
Virginie!SALAS Janvier!09! NFE107
Introduction!au!Serveurs!d d applications Définition Deux!architectures!:!Java!et!.Net BEA!Weblogic d Oracle WebSphere d IBM Inprise de!borland DNA!de!Microsoft Comparatif Un!serveur!d application!est!un!environnement!
Accès aux bases de données
13 Accès aux bases de données Les bases de données fournissent un mécanisme de stockage persistant pour les données d application et dans bien des cas, elles sont essentielles au fonctionnement des applications.
Conception de serveurs d'applications ouverts
Conception de serveurs d'applications ouverts Stéphane Frénot 3 Un modèle d'exécution standard Application Stéphane Frénot 4 1 Répartition "horizontale" d'une application Application de Présentation Application
Principes. 2A-SI 3 Prog. réseau et systèmes distribués 3. 3 Programmation en CORBA. Programmation en Corba. Stéphane Vialle
2A-SI 3 Prog. réseau et systèmes distribués 3. 3 Programmation en CORBA Stéphane Vialle [email protected] http://www.metz.supelec.fr/~vialle 1 Principes 2 Architecture 3 4 Aperçu d utilisation
Remote Method Invocation en Java (RMI)
Remote Method Invocation en Java (RMI) Modélisation et construction des applications réparties (Module M-4102C) J. Christian Attiogbé Fevrier 2015 J. Christian Attiogbé (Fevrier 2015) Remote Method Invocation
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
SGBDR. Systèmes de Gestion de Bases de Données (Relationnelles)
SGBDR Systèmes de Gestion de Bases de Données (Relationnelles) Plan Approches Les tâches du SGBD Les transactions Approche 1 Systèmes traditionnels basés sur des fichiers Application 1 Gestion clients
What s New. Sun ONE Application Server. Version 7, Enterprise Edition
What s New Sun ONE Application Server Version 7, Enterprise Edition 817-2142-10 September 2003 Sun Microsystems, Inc. 4150 Network Circle Santa Clara, CA 95054 U.S.A. Copyright 2003 Sun Microsystems, Inc.
MOM: Concepts & Applications
MOM: Concepts & Applications André Freyssinet ScalAgent Distributed Technologies [email protected] www.scalagent.com Plan Introduction Exemple d application (supervision) Synchrone vs Asynchrone
Technologies du Web. Créer et héberger un site Web. Pierre Senellart. Page 1 / 26 Licence de droits d usage
Technologies du Web Créer et héberger un site Web Page 1 / 26 Plan Planification Choisir une solution d hébergement Administration Développement du site Page 2 / 26 Cahier des charges Objectifs du site
Conception Exécution Interopérabilité. Déploiement. Conception du service. Définition du SLA. Suivi du service. Réception des mesures
Software propose une offre d intégration unique, qui apporte l équilibre parfait entre investissements et performances pour les entreprises qui doivent sans cesse améliorer leurs processus. Des caractéristiques
Rapport de projet de fin d études
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
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...
Serveur d'application à la juste taille
Serveur d'application à la juste taille 18 Mars 2010 [email protected] Plan Contexte JOnAS 5, plate-forme de convergence JavaEE/OSGi Caractéristiques essentielles pour le Cloud Computing & l'autonomic
