OSGi. Conception d applications modulaires en Java. Jérôme Molière. Préface de Peter Kriens. Groupe Eyrolles, 2012, ISBN :
|
|
|
- Louis Hébert
- il y a 10 ans
- Total affichages :
Transcription
1 OSGi Conception d applications modulaires en Java Jérôme Molière Préface de Peter Kriens Groupe Eyrolles, 2012, ISBN :
2 Préface Pour nous, qui venons du Nord, la France méridionale a bien des attraits. La douceur du climat, la bonne chère et le bon vin, les jolies femmes et les interactions sociales riches... Bref, tout un art de vivre! Mon poste de Directeur technique chez OSGi m a conduit à parcourir toute la planète, sans me laisser le loisir de séjourner trop longtemps en Suède. Malgré l envie de températures plus douces, quitter la Suède n a pas été un choix facile parce qu elle est étrangement attachante, pour un pays si froid. Pourtant, en 2003, nous avons franchi le pas et emménagé dans un endroit magnifique, Beaulieu, dans la campagne environnant Montpellier. Parmi les choses qui m ont manqué, les échanges avec mes collègues d Ericsson et les déjeuners rituels dont je garde un très bon souvenir. En effet, toute attrayante que soit la côte méditerranéenne, on n y trouve que très peu de développeurs OSGi... Aussi fus-je stupéfait d apprendre que l un des conférenciers acceptés en 2009 à la conférence OSGi DevCon à Jazoon habitait à moins de 12 kilomètres de chez moi! Je lui ai écrit pour proposer un déjeuner quel rêve en effet que de tenir une discussion approfondie sur les ClassLoaders Java tout en jouissant des fruits de «La Campagne»! C est ainsi que j ai rencontré Jérôme, qui m a non seulement fait découvrir les meilleures frites du monde (à Lansargues), mais est devenu un compagnon régulier du Bon Coin. J ai ainsi pu mesurer les efforts titanesques que demande l écriture d un livre. Au cours des dix dernières années, j ai été sollicité de nombreuses fois pour rédiger des ouvrages sur la création logicielle, mais le travail est infernal, peu rémunéré et tout à fait sousestimé. Je tire mon chapeau à tous les auteurs qui sont capables d aller au bout d une telle entreprise. En effet, il suffit au lecteur d une minute sans effort pour parcourir un texte qui a nécessité des heures muettes de dur labeur. Le processus de rédaction a confirmé l idée que je me faisais de ce travail ; je suis maintenant admiratif qu il soit terminé. Enfin un ouvrage en français sur OSGi! Il était temps, après la parution d un ouvrage en allemand, un en chinois et plusieurs en anglais, quand on sait que les racines d OSGi se situent en France et que cette norme y est assez populaire. J y vois une sorte de reconnaissance!
3 VI OSGi Conception d applications modulaires en Java Lorsque nous avons démarré OSGi, nous sommes partis du JES (Java Embedded Server) de Sun comme structure de base pour nos spécifications. L auteur de ce produit, Anselm Baird-Smith, est un Français de Grenoble. S il a quitté le projet quelques mois après, il n en demeure pas moins pour moi l auteur original du cœur de la norme. Après dix années passées à travailler sur son modèle, je reste béat d admiration pour la simplicité et l élégance du modèle OSGi original, et plus encore à présent que je réalise combien les purs programmeurs Java ont de mal à appréhender la modularité et comme ils tendent à créer un monstre dès qu ils en ont la possibilité. Certains lecteurs seront surpris qu on puisse voir en OSGi une solution simple et élégante car des développeurs se plaisent à le dénigrer sur le Web en critiquant sa complexité. Mais quand on analyse ces attaques verbales, on se rend compte qu ils reprochent à l outil de ne pas faire... ce pour quoi il n est pas fait! C est que la modularité ne s utilise pas comme une bibliothèque qu il n y aurait qu à ajouter dans son classpath... La modularité est une qualité de la structure de base de votre code. OSGi, lui, n est qu un messager donnant l alerte, lorsque votre code n est pas modulaire. Les mécontents d OSGi ne se plaignent au fond que du fait que leurs hacks non modulaires échouent dans un environnement OSGi! Malheureusement, la plupart des bibliothèques les plus utilisées ne sont pas modulaires dans leur conception. Il faudrait, pour jouir des avantages de la modularité, un remaniement en profondeur (refactoring) afin d aménager la communication entre modules. C est ce que propose OSGi avec son modèle par micro-services et ses dépendances par paquets : la solution la plus simple pour étendre Java de façon modulaire, sans toutefois perdre une sûreté de typage à laquelle les développeurs Java sont attachés. Pour comprendre OSGi, il faut être prêt à changer de paradigme, à penser différemment. Or, un tel changement est toujours mystérieux : avant l épiphanie, tout semble inutilement complexe et bruité. Mais une fois de l autre côté, tout s éclaire comme par magie et la cause des problèmes entrevus auparavant devient péniblement évidente. J en ai fait l expérience plusieurs fois dans ma vie, avec la programmation objet, la programmation fonctionnelle (avec Prolog!), l inversion de contrôle... non sans peiner à chaque fois. Pour pimenter le tout, impossible de franchir la distance sur de simples explications, puisqu on ne peut comprendre qu à partir de ce qu on sait déjà. Voilà pourquoi ce livre est aussi important. Il offre une introduction pratique à OSGi avec de nombreux exemples, sans oublier d en approfondir les aspects fondamentaux, à savoir les dépendances de paquets et les micro-services. Lorsque vous en lirez les explications, et en testerez les exemples, le chemin vous semblera ardu. Mais les leçons en valent la peine car elles vous donneront un précieux recul sur votre code, ainsi que sur la manière de l optimiser et de le rendre plus modulaire. Peter Kriens
4 Table des matières Avant-propos... 1 CHAPITRE 1 OSGi pour une conception modulaire... 3 OSGi, pour quelles applications? Cas d une automobile Cas d un environnement de développement (IDE) Cas d un serveur d applications Problèmes liés au paquetage des applications J2EE Regrouper des bibliothèques au sein d un conteneur OSGi Vers les architectures orientées services Dépasser les limitations dues aux ClassLoader Java Tour d horizon de la norme OSGi et de ses services Couplage et injection de dépendances? Les bundles OSGi Les spécifications OSGi en détail Implémentations OSGi CHAPITRE 2 Exemples d applications modulaires basées sur OSGi OSGi comme socle architectural de serveur : JOnAS Le shell OSGi sous JOnAS Un bref survol du code source de JOnAS OSGi pour les applications embarquées : serve@home Le projet domotique serve@home de Siemens OSGi dans les automobiles CHAPITRE 3 Mettre en place son premier bundle OSGi Installation de bndtools Création du projet et développement du bundle
5 VIII OSGi Conception d applications modulaires en Java Création du projet Méta-informations nécessaires Bundles et bibliothèques Java utilisés OSGi et chargement de classes Encapsulation de la bibliothèque Commons Lang Services OSGi par défaut Publier son premier service OSGi Gestion du dynamisme avec le tracking de services S appuyer sur les services standards de la plate-forme CHAPITRE 4 Travailler avec OSGi : environnement et outils Conteneurs OSGi Apache Felix Le projet Knopflerfish La console OSGi d Eclipse : Equinox Choisir sa console Nécessité d un référentiel de bundles : OBR OSGi et bundles : limitations Vers un entrepôt commun de bundles avec OBR Premier contact avec OBR Architecture et dynamique d appels avec OBR Les plug-ins de développement Eclipse pour OSGi Simplifier la création de bundles avec bnd Travailler avec bnd Utiliser bndtools ipojo : une autre approche du développement OSGi PDE : l environnement standard de développement de plug-in d Eclipse CHAPITRE 5 Le moteur d injection de dépendances : la spécification Declarative Services Introduction à la déclaration de services dans OSGi Le SCR (Service Component Runtime) Fonctionnalités proposées par le SCR Activation immédiate ou retardée? Principes pour la mise en œuvre de SCR Exemple complet Descriptif du produit Entités en présence
6 Table des matières IX Application en utilisation L exemple vu du côté technique Conception Code source et descripteurs de déploiement Précisions sur le Declarative Services CHAPITRE 6 Services OSGi pour le développeur : LogService, EventAdmin, HttpService et ConfigAdmin Gestion des traces avec le LogService Communication par messages avec l EventAdmin Présentation Fonctionnalités et limitations Principales entités mises en jeu Exemple de mise en œuvre Exposer ses ressources sur le Web avec l HttpService Service de configuration : le ConfigAdmin Présentation Conclusion CHAPITRE 7 Modularité et tests unitaires Retour sur la notion de modularité Du point de vue du chef de projet Du point de vue du programmeur Du point de vue de l architecte Modularité et tests en environnement OSGi Les commandes du shell Tests en environnement OSGi Principe du test unitaire en environnement OSGi Création de l environnement d exécution des tests unitaires Mise en pratique : création d un test case pour un service OSGi simple Considérations avancées Gestion des versions de composants en environnement OSGi Qu est-ce qu une version d un composant et d une application? La vision offerte par OSGi en matière de gestion de versions Adopter une numérotation cohérente et en tirer parti Gestion de la politique de numérotation des versions en pratique Ce qu il faut retenir
7 X OSGi Conception d applications modulaires en Java CHAPITRE 8 Design patterns OSGi et bonnes pratiques Gabarits de conception Séparation entre API et implémentations Le design pattern Factory Le design pattern du tableau blanc ou Whiteboard Comment fonctionne le WhiteBoard? Invocation dynamique de code dans le contexte OSGi Exemple de situation : sérialisation/désérialisation de données avec Castor XML Mise en place pratique Conseils et pièges à éviter Shells OSGi et niveaux de démarrage Gestion de la problématique des versions Injection de dépendances Maîtrise de la méta-information CHAPITRE 9 Application exemple L application exemple Vue d ensemble de l architecture Notes relatives à la conception de l application Création des PDF Planification de tâches en Java Quelques images du produit Notes relatives à l implémentation Encapsulation d une bibliothèque Java standard Commandes du shell Utilisation de Cron4J Finalisation du projet Le code source Planification de tâches Encapsulation de SQLite Le DAO SQLite Descripteur de l application Ce qu il faut en retenir ANNEXE Mettre en place un bundle OSGi avec PDE Index
8 Avant-propos Depuis environ deux ans, de nombreux produits voient leurs architectures complètement modifiées pour adopter une conception conforme à la norme OSGi. Que peut apporter cette norme au développeur et concepteur? Que propose-t-elle? Quel modèle et quels outils utiliser? Pourquoi ce livre? Ce livre cherche à présenter en douceur la plate-forme OSGi, ainsi que l environnement gravitant autour. Il comporte une section dédiée à l outillage, ainsi qu une section, plus rare en comparaison des ouvrages existants, consacrée aux aspects de conception en environnement OSGi. Cet ouvrage ne tente pas d entrer dans les arcanes d un conteneur OSGi ni de détailler chacun des aspects de la norme ; il se veut une introduction cohérente à cette technologie. Pour aller plus loin dans la technique, l auteur ne peut que chaudement conseiller la lecture de l indispensable OSGi in Action paru chez Manning et cosigné par Richard S. Hall, un des meilleurs spécialistes d OSGi. R Richard S. Hall, Karl Pauls et Stuart McCulloch, OSGi in Action, Manning, 2011
9 2 OSGi Conception d applications modulaires en Java À qui s adresse ce livre? Cet ouvrage s adresse aux étudiants, ingénieurs, architectes et chefs de projets expérimentés en Java et qui s intéressent aux problématiques de modularité, ou qui doivent s adapter à des contraintes liées au déploiement en environnement embarqué : développeurs JEE, développeurs RCP Structure du livre Après avoir esquissé le contexte architectural actuel, nous présenterons la notion de services propre au monde OSGi, puis nous aborderons la façon de travailler et de penser une application pour cette technologie. Enfin, nous illustrerons les concepts évoqués sur un cas pratique simple. Remerciements L auteur tient à remercier chaleureusement Peter Kriens, qui a toujours été à son écoute et a apporté des solutions sages et le plus souvent élégantes, tout en enrichissant ses réponses d anecdotes croustillantes sur la face cachée d une norme telle qu OSGi. Il le remercie pour ses relectures précieuses, ainsi que Vincent Beretti et Christophe Peigné. Il est naturel de remercier Karine Joly, Muriel Shan Sei Fan et Anne Bougnoux, le trio d éditrices de choc ayant participé à la gestation puis à la finalisation de ce livre, ainsi que Sophie Hincelin, Anne-Lise Banéath et Gaël Thomas, qui ont œuvré avec minutie et efficacité lors des dernières étapes. De plus, cet ouvrage n aurait pas été possible sans la mission effectuée au sein de Telintrans. Enfin, merci à ceux ayant subi les affres de la mauvaise humeur de l auteur. BIBLIOGRAPHIE R R. S. Hall, K. Paul, S. McCullogh, OSGi in Action, Manning, 2011 R E. Gamma et al., Design Patterns: Elements of Reusable Software Components, Addison Wesley, 1994 R C. Beust, H. Suleiman, Next Generation Java Testing, Addison Wesley, 2007
10 1 OSGi pour une conception modulaire OSGi (autrefois Open Services Gateway Initiative) est le nom d une plate-forme orientée, à l origine, vers l embarqué, et dédiée à la gestion d applications extrêmement configurables et dynamiques dans un environnement à une seule machine virtuelle Java. Ce premier chapitre a pour but de placer la plate-forme OSGi dans le contexte des applications modernes, de manière à justifier son utilisation dans des conditions a priori opposées : de l application embarquée jusqu au serveur d applications. Il présente enfin les spécifications d OSGi et les services qu elle prévoit. OSGi, pour quelles applications? Cette section examine quelques types d applications contemporaines (automobile, environnement de développement, serveur d applications) pour en extraire des besoins techniques communs. Cette collecte nous amènera naturellement vers une vue d ensemble de la plate-forme OSGi.
11 4 OSGi Conception d applications modulaires en Java Cas d une automobile Objet de la vie de tous les jours, une voiture récente est un véritable écosystème d applications informatiques, pour peu qu elle dispose d équipements du type : ABS (antiblocage de sécurité, système empêchant le blocage des roues en cas de freinage violent), dispositif nécessitant un logiciel à même de contrôler divers paramètres comme l intensité du freinage, la vitesse, éventuellement le type de revêtement, etc. ; ESP (Electronic Stability Program, système de lutte contre le patinage, qui réduit le couple moteur dans certaines conditions de circulation où l adhérence est problématique), dispositif qui requiert une application contrôlant le régime moteur en fonction d un algorithme collectant ses entrées par le biais de capteurs ; lecteur CD ou MP3/DivX ; gestionnaire d air conditionné ; etc. Il existe ainsi des dizaines d applications disséminées dans une automobile. Cet exemple nous donne l occasion de formuler quelques remarques. Tout d abord, ces applications sont nombreuses et doivent cohabiter dans le même environnement, même si elles ne sont pas toutes du même niveau de criticité. En outre, elles ont des cycles de vie fort distincts, puisque certaines sont résidentes (du démarrage jusqu à l arrêt du véhicule), alors que d autres peuvent n être effectives que pour quelques secondes. Quant à l environnement d exécution, il est nécessairement cloisonné, de manière à ne pas voir une application critique tomber sous prétexte qu une application d importance moindre a provoqué des erreurs. Enfin, ces applications forment un véritable microcosme et interagissent. En effet, plusieurs applications peuvent demander une modification du régime moteur, sans pour autant que le code correspondant soit dupliqué. Elles vont donc toutes s adresser à une même application fournissant le service d augmentation ou diminution du régime. Pour citer Peter Kriens, le chantre d OSGi, il est amusant de noter qu un simple lecteur DivX représente le même nombre de lignes de code que l informatique d un programme spatial des années 1960, tandis que l on constate que le volume du code à l échelle planétaire double tous les 7 ans.
12 OSGi pour une conception modulaire CHAPITRE 1 5 Cas d un environnement de développement (IDE) Quels sont les services attendus par un utilisateur d IDE (Integrated Development Environment)? Ils sont fort variés, même si en premier lieu, on s attend à trouver des facilités pour : l édition du code dans un langage donné ; le débogage de code ; le pilotage de l exécution et du déploiement de nos applications. Outre ces besoins courants, on peut rechercher une intégration avec des serveurs d applications dans le monde Java, avec Apache dans le monde PHP. On peut avoir besoin d outils de visualisation de traces, de consoles permettant un accès SSH (Secure Shell) vers un serveur, etc. Comme il est impossible de dresser une liste exhaustive de ces besoins, l architecture de tels produits doit donc prévoir un socle générique offrant diverses facilités transverses. En enrichissant les fonctionnalités de ce socle par l ajout de greffons, on aboutit à l idée de plug-ins présente dans Eclipse, ou encore à celle de modules dans le cadre de l architecture NetBeans. Un IDE récent doit donc offrir un large éventail d extensions et un cadre de développement de ces extensions de manière à couvrir de nombreux besoins distincts. Figure 1 1 Contenu du répertoire plugins pour Eclipse/Ganymede orienté J2EE Les figures 1-1 à 1-4 montrent les contenus des répertoires d extensions fournis avec les deux environnements majeurs de développement du monde Java : NetBeans et Eclipse. Ce dernier ne comporte pas moins de 583 plug-ins, alors que NetBeans couvre sensiblement le même spectre de fonctionnalités avec tout de même
13 6 OSGi Conception d applications modulaires en Java 40 modules (la granularité des modules NetBeans n est pas exactement comparable à celle d un plug-in ou bundle dans Eclipse)! Figure 1 2 Contenu du répertoire modules de NetBeans 6.5 Figure 1 3 Nombre de modules dans un NetBeans 6.5/All Figure 1 4 Nombre de plug-ins dans Eclipse Ganymede JEE5 sous Linux Évidemment, une telle profusion de besoins s accompagne, parfois pour ces produits, de la nécessité de fonctionner sur des machines n étant pas des bêtes de course. Il est donc impératif que l architecture des IDE récents permette un chargement à la demande des extensions, afin de laisser disponible un volume maximal de mémoire pour un fonctionnement raisonnable du programme.
14 OSGi pour une conception modulaire CHAPITRE 1 7 DÉFINITION Lazy loading : le chargement à la demande Cette stratégie de chargement est opposée à une politique plus brutale, consistant à charger tout au démarrage. On retrouve ces noms de politiques dans des produits comme Hibernate. Il est logique de désactiver les ressources requises pour travailler en PHP quand on se prépare à travailler sur un serveur de sources Subversion, par exemple. Évidemment, cette stratégie impose de nombreux accès au disque ; tout avantage a sa contrepartie. Cas d un serveur d applications Un tel serveur est un hôte pour vos applications ; il met à leur disposition diverses ressources : pool de connexions JDBC par le biais de DataSource JDBC ; annuaires LDAP par le biais de JNDI ; autres ERP par le biais de connecteurs JCA Le serveur fournit également des services techniques : sécurité avec JAAS ; persistance avec JPA ; transactions par JTA. Les applications ainsi hébergées vont utiliser des bibliothèques Java et se doivent de disposer d un taux de disponibilité maximal. Rationaliser leur utilisation, en évitant un chargement multiple de la même bibliothèque au gré des humeurs des développeurs créant les paquetages, rend plus robuste l ensemble des applications. Enfin, une autre fonctionnalité est souvent désirée concernant un serveur d applications : le fait de pouvoir exposer diverses versions de la même application chose impossible jusque récemment. EN CLAIR JDBC LDAP JNDI ERP JCA JAAS JPA JTA Java DataBase Connectivity Lightweight Directory Access Protocol : protocole de gestion d annuaires de réseau Java Naming and Directory Interface : extension Java pour l accès aux services d annuaire Enterprise Resources Planning : progiciel de gestion d entreprise J2EE Connector Architecture : interface d accès aux applications Java Java Authentification and Authorization Service Java Persistence API Java Transaction API
15 8 OSGi Conception d applications modulaires en Java Problèmes liés au paquetage des applications J2EE Après avoir effectué des dizaines d audits d applications J2EE déployées sous Tomcat, JBoss, JOnAS ou WebLogic, il m est possible de désigner la mise en paquetage d une application comme un facteur de fortes perturbations pour la stabilité d un serveur. Ainsi, du bytecode inutile empaqueté en archives.jar influera sur la taille de la zone de la mémoire Java connue sous le nom de PermGen, zone contenant principalement le bytecode Java (mais aussi les interns propres aux instances de java.lang.string pour les JVM antérieures à la version 1.7). Fréquemment négligé, cet aspect induit de nombreux problèmes liés au paramétrage du ramasse-miettes (garbage collector) si l on déploie des archives ( JAR) contenant beaucoup de bibliothèques inutiles. La zone dénommée PermGen se trouvant favorisée par nécessité, les zones destinées aux objets à durée de vie moindre sont donc réduites. Cela induit de sévères risques lors de la phase d exécution de l application en forçant des promotions non désirables et en entraînant la multiplication de passages plus laborieux du ramasse-miettes en mode full (avec scan des zones de la hcap). EN CLAIR JVM JAR Java Virtual Machine Java ARchive Regrouper des bibliothèques au sein d un conteneur OSGi Si vous encapsulez vos bibliothèques en tant que bundles OSGi (donc versionnés) et si vous énoncez vos dépendances sous forme de clauses import-paquetage, vous permettrez au conteneur OSGi de réellement partager les dépendances usuelles et donc d économiser des ressources. En même temps, cela permet de gérer aisément le cas où deux bundles utilisent deux versions différentes de la même bibliothèque puisque chaque bundle OSGi se voit isolé dans son propre ClassLoader. VOCABULAIRE Première définition du «bundle» Ce terme sera expliqué longuement par la suite ; il suffit pour l instant de présenter un bundle comme étant l unité de déploiement atomique au sein d OSGi. Un bundle, archive.jar enrichie de méta-informations, est donc un module au sein de votre application.
16 OSGi pour une conception modulaire CHAPITRE 1 9 L informatique d aujourd hui est complexe, s appuie sur de nombreux composants qui doivent interagir sans pour autant être trop couplés, au risque de voir la maintenance évolutive des applications se transformer en cauchemar. Il est crucial d envisager les relations entre composants comme un véritable dialogue client/serveur ou encore client/fournisseur. Cette approche nous oblige à nous centrer sur les services requis pour le fonctionnement d un composant, ainsi que sur les services qu il offre à l extérieur. Nous nous plaçons dans une optique résolument tournée vers le SOA (Services Oriented Architecture, architecture orientée service), où l important est de voir notre demande de service aboutir, sans s occuper de qui l a honorée, ni de comment (par quelle implémentation ou quel code) cette requête a abouti. Vers les architectures orientées services La SOA véhicule l idée que le seul moyen de maîtriser une application le long de son cycle de vie est de faire en sorte d en maîtriser le couplage. Cela demande d attendre de nos applications qu elles présument le minimum de choses possibles quant aux composants externes utilisés. Ainsi, éviter un couplage fort avec une version spécifique de Log4J ou avec un parseur XML permet d intégrer facilement les bénéfices apportés par une version ultérieure de ce produit. Comment arriver à un tel découplage? En manipulant des API (versionnées) et en réclamant pour nos composants que leur environnement d exécution leur fournisse une version compatible avec nos exigences. N entrons pas pour l instant dans la mise en pratique concrète il faudra pour cela attendre le chapitre 3 mais concentrons-nous sur les concepts. À ce stade, nous devons repenser nos composants de manière à isoler clairement, pour chacun d eux, trois parties : l API publique exposée aux autres, à savoir ce que les autres pourront utiliser ; les API externes utilisées ; l implémentation, devant rester totalement opaque vis-à-vis du monde extérieur. Ceci va se traduire formellement par une représentation du composant utilisant les symboles suivants : un arc de cercle pour désigner un service proposé à l extérieur (aux autres composants) ; un trait terminé par un point pour désigner un service extérieur requis par le composant.
17 10 OSGi Conception d applications modulaires en Java La figure 1-5 montre comment un composant A propose un service utilisé par un composant B, tout en utilisant un service offert par un composant C. Figure 1 5 Un composant A propose un service utilisé par le composant B tout en utilisant un service proposé par le composant C. SOA XML et déploiement Dans la littérature, on parle de SOA en sous-entendant l utilisation de flux XML et de services web, en s appuyant sur des briques logicielles orchestrant les dialogues entre applications (EAI, Enterprise Application Integration) comme ceux proposés par la norme JBI (Java Business Integration). Ici, on s intéresse plutôt à l idée architecturale de découplage, de responsabilités de tâches (microservices), en faisant fi de l aspect déploiement sur des machines, middleware et protocolaire. Notez qu il n y a pas d équivalence stricte entre bundle et service (microservice). En effet, un bundle peut légitimement fournir plusieurs services à la plate-forme tandis qu un même service pourra être déployé plusieurs fois (en diverses versions ou en diverses implémentations fournissant toutes la même version du paquetage correspondant à ce service). Le chapitre 6 sera dédié à cette notion de services dans la norme OSGi, donc n anticipons pas trop... EN CLAIR SOA EAI JBI Service Oriented Architecture Enterprise Application Integration Java Business Integration Dépasser les limitations dues aux ClassLoader Java Java s appuie sur la notion de chargeur de classes (ClassLoader), de manière à rendre possible le chargement de classes par le réseau, en base de données ou par n importe quel autre flux. Il n y a pas, au sens strict du terme, un seul ClassLoader, mais plutôt
18 OSGi pour une conception modulaire CHAPITRE 1 11 une hiérarchie de ClassLoaders, chacun responsable du chargement d une partie des classes nécessaires à une application. Il est possible de développer ses propres chargeurs de classes répondant à tel ou tel besoin précis. Des applications comme JBoss ou Tomcat, avec leurs besoins de redéploiement à chaud, utilisent évidemment cette possibilité. Ainsi, dans JBoss, c est par le biais de la création d un tel ClassLoader (UnifiedClassLoader) que des possibilités comme le démarrage par le réseau étaient possibles. La figure 1-6 montre l organisation des ClassLoaders dans une application standard, en associant pour chaque niveau les classes concernées. La stratégie de délégation par le parent en premier a un certain nombre d avantages, mais présente aussi son lot de désagréments. Figure 1 6 Organisation des ClassLoaders dans une application standard La figure 1-7 détaille la séquence propre à toute implémentation d un ClassLoader spécifique. On peut imaginer différents moyens de stocker le code compilé correspondant à des classes Java avec notamment les cas de figure suivants : un serveur TCP type serveur web ou FTP ; une base de données qui permet avec des champs de type BLOB de stocker du binaire pur ; un système de fichiers.
19 12 OSGi Conception d applications modulaires en Java Figure 1 7 Séquence propre à toute implémentation d un ClassLoader spécifique Exemple simpliste d un ClassLoader chargeant des classes depuis un système de fichiers import java.io.*; import java.net.*; import java.util.*; public class FileClassLoader extends ClassLoader { private String root; public FileClassLoader (String rootdir) { if (rootdir == null) throw new IllegalArgumentException ("Ne peut charger de classes depuis un répertoire nul!!!"); root = rootdir; } /** implémentation de loadclass() renvoie une instance de java.lang.class ou lève une ClassNotFoundException */ protected Class loadclass (String name, boolean resolve) throws ClassNotFoundException { Class c = findloadedclass (name); if (c == null) { try {
20 OSGi pour une conception modulaire CHAPITRE 1 13 c = findsystemclass (name); } catch (Exception e) { } } if (c == null) { /** remplace les séparateurs de noms de paquetages par des / pour trouver * le fichier équivalent au nom de classe passé en argument */ String filename = name.replace ('.', File.separatorChar) + ".class"; try { byte data[] = loadclassdata(filename); c = defineclass (name, data, 0, data.length); if (c == null) throw new ClassNotFoundException (name); } catch (IOException e) { throw new ClassNotFoundException ("Erreur rencontrée lors de la lecture du fichier : " + filename); } } if (resolve) resolveclass (c); return c; } // charge le bytecode correspondant à la classe private byte[] loadclassdata (String filename) throws IOException { File f = new File (root, filename); int size = (int)f.length(); byte buff[] = new byte[size]; FileInputStream fis = new FileInputStream(f); DataInputStream dis = new DataInputStream (fis); dis.readfully (buff); dis.close(); return buff; } } ALLER PLUS LOIN Ressources sur ce sujet Divers sites, ouvrages et magazines proposent de très bonnes introductions à cette problématique du chargement des classes en Java : B B B R J. Engel, Programming for the Java Virtual Machine, Addison Wesley, 1999 R Li Gong, Gary Ellison, Mary Dageforde, Inside Java 2 Platform Security: Architecture, API Design and Implementation, 2 e edition, Prentice Hall, 2003
21 14 OSGi Conception d applications modulaires en Java Ainsi, OSGi permet d implémenter de belles architectures orientées service au sein d une machine virtuelle, à condition de définir clairement les services exposés publiquement et ceux consommés par chaque composant et ce, en définissant de réels modules réutilisables à l infini sous la forme de bundles. Ces notions n ont pas encore été présentées et seront développées par la suite, mais nous pouvons déjà dire qu OSGi s appuie sur le format de paquetage standard en Java (fichiers.jar) pour déployer ces modules (bundles) et qu ils piocheront les méta-informations nécessaires dans le fichier META-INF/MANIFEST.MF. Nous le préciserons dans les chapitres ultérieurs. Tour d horizon de la norme OSGi et de ses services OSGi est une norme qui spécifie comment écrire des applications déployables dans tout conteneur OSGi (conforme à la norme) en tirant parti de différents services normalisés : la gestion des traces (LogService) ; la publication dynamique de ressources ou d applications via un serveur HTTP embarqué (HttpService) ; la gestion de préférences ; la gestion de périphériques UpnP ; l injection de dépendances par le biais du Declarative Services (ou SCR). Le but est de fournir une API qui découvre des services apparaissant ou disparaissant à la volée, tout en assurant une cohérence entre diverses versions d implémentations d un même service. Cet ensemble de spécifications s attache à fournir une solution à la fois légère et efficiente, mais aussi élégante, avec une emphase particulière sur la modularité. CULTURE De la SOA aux architectures SCA On pourrait voir OSGi comme une plate-forme fortement inspirée des architectures SCA (Software Component Architecture) en réduisant le spectre au seul langage Java et focalisée sur une implémentation mono-jvm même si Distributed OSGi vise à élargir cette vision. SCA est une technologie poussée par IBM et Oracle. Elle préconise l assemblage de composants hétérogènes communiquant par le biais de protocoles standardisés, afin de rendre l ensemble indépendant des choix technologiques (plates-formes matérielles, langages d implémentation mis en œuvre ). C est la plus aboutie des mises en œuvre des principes de la SOA.
22 OSGi pour une conception modulaire CHAPITRE 1 15 EN CLAIR SCA SOA Software Component Architecture Service Oriented Architecture Depuis sa conception (1998), OSGi visait à résoudre les problèmes liés aux applications embarquées, un monde dans lequel toute ressource se doit d être exploitée pleinement et toute dépense justifiée. C est ainsi qu un environnement OSGi complet tel que Felix (l implémentation du projet Apache) ne réclame que un ou deux mégaoctets de RAM. Cet environnement constitue le socle pour accueillir toute application, quel que soit son cadre de développement. L accent est mis sur la possibilité d obtenir un système extrêmement dynamique, au sein duquel la maîtrise du couplage logiciel est essentielle. C est à ce titre qu OSGi, par son approche orientée services, est utile, car elle favorise justement le découplage entre composants. Qu en est-il cependant de la modularité promise? Nous reviendrons sur le sujet plus loin ; retenons déjà qu en découplant les interfaces des implémentations et en veillant à n utiliser que des interfaces par le biais d une injection de dépendances du type SCR, la plate-forme OSGi va permettre de remplacer n importe quelle brique (bundle) par une autre, tout en fournissant les mêmes services, et ce, dynamiquement. Couplage et injection de dépendances? Au sens du génie logiciel, le couplage entre deux composants traduit le degré de dépendance d un composant envers l autre. Dès lors qu il y a couplage important entre deux composants, il y a une plus grande difficulté en cas de changement et cela influe sur la gestion des deux composants. Un couplage fort induit des modifications dans le composant utilisateur, dès que l on modifie le composant qu il utilise. Notez qu on retrouve le même type d effets lors de l utilisation d attributs en programmation orientée objet classique et en cas de non-respect du principe fondamental de l encapsulation. Quant à l injection de dépendances, elle est nécessaire lorsque l implémentation d un composant peut requérir des services offerts par un autre composant en utilisant un pattern de délégation. Le choix, au moment de la compilation, du composant qui va réaliser ce service est un frein à l évolution du produit car tout changement futur va réclamer une coûteuse procédure de recompilation, redéploiement et redémarrage. L injection de dépendances repousse ce choix à la phase d exécution. Ce choix peut être réalisé par un composant tel que Spring (qui fait de l injection statique car
23 16 OSGi Conception d applications modulaires en Java guidée par des informations XML ou des annotations positionnées dans le code Java) ou, dans le cas d OSGi, par un service de gestion des dépendances qui propose une version dynamique de l injection. Les bundles OSGi Dans le vocabulaire spécifique OSGi, un module déployé au sein de la plate-forme OSGi est appelé un bundle. Par extension, dans le cas de la programmation RCP, on devrait remplacer la notion de plug-ins par celle de bundles, mais les traditions restent. Comme nous l avons déjà dit, un bundle est en fait déployé en tant que fichier.jar avec des méta-informations lues par le conteneur OSGi et fournies par le fichier META-INF/MANIFEST.MF. VOCABULAIRE RCP RCP, pour Rich Client Platform, désigne un mode de déploiement et de programmation fournissant une alternative aux interfaces web (et donc à leurs limitations) en autorisant des interfaces graphiques riches en fonctionnalités. C est l option opposée aux clients dits légers puisqu il s agit là de déployer des applications s appuyant sur l environnement développé pour Eclipse (SWT et autres bibliothèques) ou autour de NetBeans (Swing, etc.). Les développeurs Java ayant fait de l analyse d application ont peut-être déjà utilisé un tel outil avec la célèbre Visual-VM et son plug-in Visual-GC qui se basent sur l infrastructure NetBeans RCP. Les spécifications OSGi en détail OSGi découle des travaux d industriels et de spécialistes du logiciel regroupés au sein d une association : l OSGi Alliance. Celle-ci gère des versions de spécifications qui sont organisées de la façon suivante : Core : le cœur d OSGi, qui fournit les entités centrales et leurs liens, c est-à-dire les classes Bundle et BundleContext. Compendium : extensions presque indispensables du cœur de la plate-forme OSGi, avec les différentes interfaces définissant les services standardisés. Nous verrons ces services et comment les utiliser dans les chapitres suivants. En plus de ces deux spécifications, l Alliance gère une extension de la plate-forme, appelée Enterprise OSGi, qui propose des fonctionnalités supplémentaires dédiées aux applications d entreprises avec notamment : l intégration de l API de gestion de la persistance ( JPA) ; l intégration Spring. Diverses implémentations de ce standard existent, dont Apache Aries et Eclipse Libra. D autres initiatives moins connues émanent de l OSGi Alliance et ne sont
24 OSGi pour une conception modulaire CHAPITRE 1 17 plus forcément d actualité avec des projets autour de l automobile notamment (VEG pour Vehicule Expert Group). Enfin, nous l avons évoqué, l architecture OSGi se rapproche de l architecture SCA avec les travaux menés sur Distributed OSGi visant à offrir une extension multi- JVM des concepts offerts par OSGi. Parmi les différents produits sur le marché, on peut citer Nimbus et Fabric de la société Paremus ( Implémentations OSGi OSGI est une norme et, à ce titre, elle peut trouver diverses implémentations adhérant à divers niveaux de spécifications. En dehors de l implémentation de référence basique fournie sur le site officiel, on peut citer : Equinox : l implémentation OSGi du consortium Eclipse, la véritable moelle épinière d Eclipse, mais qui peut être utilisé de manière indépendante ; Apache Felix : l implémentation de la fondation Apache ayant bénéficié de l expertise de Richard Hall et de dons de la part de la fondation ObjectWeb ; Knopflerfish : une autre implémentation de qualité. Nous reparlerons des conteneurs OSGi en fin de chapitre 4. Eclipse n est pas le seul produit à tirer bénéfice de cette plate-forme. On compte également de nombreux serveurs JEE : JOnAS 5, le serveur J2EE de la fondation OW2, basé sur OSGi (Felix) ; Glassfish v3 ; JBoss qui depuis sa version 5 expose une facette de son micronoyau en OSGi ; Websphere depuis la version 7 propose un service pack d intégration OSGi. La plate-forme OSGi, de par ses qualités d architecture (dynamisme, maîtrise du couplage), s impose donc même sur ces environnements fort éloignés des cas d utilisations ciblés au départ qu étaient les environnements légers pour applications embarquées.
25 Index A activate() 48 ANT build-file 66 Ant 122 AOP - Aspect Oriented Programming 109, 157 Apache Ace 145 Apache Aries 16 Apache Celix 44 Apache Felix 15, 17, 22 23, 38 39, 56, 58, 60, 62, 66 67, 71, 91, 98, 105, 114, 133, 145, 150, 155 API 119 commande du shell 117 felix-scr 75 File-Install 121, 145 WebConsole 87 Apache Maven 60 API - Application Programming Interface 138 application embarquée 4, 15, 29 J2EE 8 application embarquée 29 architecture orientée services 9 B bibliothèque Java 39 Java standard 154 bnd 32, 34 35, 41, 64 65, 75, 88, 90, 96, 98, 128, 154, 158 bndtools 113 description de bundle 49 bnd.bnd 36 bndtools 31, 33 34, 66, 75 76, créer un projet 33 installation 32 broker de messages 93 bundle OSGi 8, 16, 31, 39, 50, 76, 88, 110 couplage/découplage 93 création 32, 34, 67 dépendance 59 déploiement 36, 43, 65, 67 descripteur 35 36, 46, 59, 66 67, 78, 85, 144, 158, 166 encapsulation 40 41, 59 gestion des versions 73, 126 Import-Package 35 méta-information 34, 65, méthode main() 34 Private-Package 35 référentiel 58 Service-Component 35 test unitaire 119, 121 tester la conformité avec la norme 58 Bundle-Version 41 C cardinalité 85 Castor XML 140 classe Java standard 34, 67 ClassLoader Java 10, 12 commande du shell 155 ConfigAdmin 100, 130 propriétaire de la configuration 103 conteneur OSGi 8, 14, 19, 34, 50, 56, 88 couplage/découplage d application 9, 15, 31, 44, 49, 51, 53, 100, 110 couplage/découplage de composants 151 Cron4J 153, D DBC - Design By Contract 109, 128
26 176 OSGi Conception d applications modulaires en Java Declarative Services 76, 85, 114, 130 dépendance 8, 48, 59, 68, 71 circulaire Distributed OSGi 17 E EAI - Enterprise Application Integration 10 EasyMock 111 Eclipse 17, 19, 21, 32 33, 40, 42, 52, 57 58, 65 68, 76, 91, 113, 122, 127, 158 bndtools 75, 154 Market Place 32 PDE 31, 56, 147 plug-in 5 6 Eclipse Libra 16 EJB - Enterprise Java Beans 138, 147 encapsulation 149 Enterprise OSGi 16 entrepôt de composants 60 environnement de développement 19 Equinox 17, 19, 36, 38 39, 52, 57 58, 62, 66, 145 API 119 ERP - Enterprise Resources Planning 7 Event Service 74 EventAdmin 92 93, 98 EventHandler 93 Export-Package 41, 45, 137 F Fabric 17 File-Install 155 G gabarit de conception 129 Factory 130 Whiteboard 130, 133, 137, 149 gestion des périphériques 14 des préférences 14, 101 des traces 14, 88 des versions 125, , getservicereference() 48 GlassFish 17, 19 20, 56 Google GUICE 70 H Hibernate 137 HttpService 98, 100, 130 whiteboard 98 HttpService Whiteboard 134 I IDE - Integrated Development Environment 5 implémentation OSGi 17 Import-Package 40, 59, 112 Include-Resource 158 injection de dépendance 14 15, 49, 69 71, 75, 81, 85, 105, 112, 115, 130, 138, 146, 149, dynamique 72 invocation dynamique de code 137 IoC - Inversion of Control 70 ipojo 67 itext 150, Ivy 127, 138 J JAAS - Java Authentication and Authorization Service 7 JAR - Java ARchive 8, 35, 40, 64 65, 75, 154, 158 java.lang 140 java.lang.reflect 140 JBI - Java Business Integration 10 JBoss 17, 19 JCA - J2EE Connector Architecture 7 JDBC - Java DataBase Connectivity 7, 158 JDK - Java Development Kit 20 Jetty 98, 100, 130 JMS - Java Message Service 92 93, 138 JNDI - Java Naming and Directory Interface 7, 65, 138 JOnAS 17, 19, 21, 56, 65 classe de lancement 26 classe JOnAS 25 code source 24 script de lancement 22 shell OSGi 22 JPA - Java Persistence API 7, 16, 157 JTA - Java Transaction API 7
27 Index 177 JUnit 120 JVM - Java Virtual Machine 8, 28, 56, 58, 92 K Karaf API 119 Knopflerfish 17, 56, 58, 62 L LDAP - Lightweight Directory Access Protocol 7 LogService 51, 92, 95, 103 M MANIFEST.MF 28, 35, 40 41, 45, 48, 59, 64 65, 75, 112, 126, 128, 137, 147 Maven 65, 122, , 138, 147 META-INF/MANIFEST.MF 14, 16, 35, 50 méta-information 67, 70, 73, 112, 137, 147 micronoyau 22 modularité 110 MOM - Message Oriented Middleware 53, 93 N NetBeans 58, 60 module 6 Nimbus 17 norme OSGi 14, 16 O objet mock 111 OBR - OSGi Bundle Repository 56, 60 architecture 63 Oscar 56, 60 OSGi chargement de classe 40 Declarative Services 67 environnement 55 plug-in de développement Eclipse 64 service 67 service de lancement d un conteneur 27 OSGi Alliance 16, 58 OSGI-INF 85, 112 OSGI-OPT 73 P paquetage 35, 41 PDE - Plug-in Development Environment 66 67, 113, 169 planification de tâche 153, 156 POJO - Plain Old Java Object 67, Posh 119 Private-Package 47 propriétaire de la configuration 103, 108 publication dynamique via HTTP 14 Q Quartz 153, 156 R RCP - Rich Client Platform 16, 68 S SCA - Software Component Architecture 15, 17 SCR - Service Component Runtime 70 71, 75, 84, 88, 96, 105, 108, 114, 145 exemple d utilisation 76 fonctionnalité 71 mise en œuvre 73 sérialisation/désérialisation de données 137, 140 serve@home 29 serveur d applications 7 serveur J2EE 17 service OSGi 14, 35, 44, 51, 74, 114, 156 cardinalité 72 ConfigAdmin 88, 159 déclaration 70 Declarative Services 108, 151, disponibilité EventAdmin 72, EventService 95, 149 HttpService 98, 133, 136, 150 LogReaderService 88 LogService 72, 87, 149 Metatype 87 par défaut 43 publier 44 test unitaire 121 Service-Component 47 ServiceReference 95, 98
28 178 OSGi Conception d applications modulaires en Java ServiceTracker 50, 133 ServletTracker 135 shell OSGi 117, 145 ShutdowHookThread 28 ShutdownHookThread 27 SOA - Service Oriented Application 128 SOA - Services Oriented Architecture 9 10, 15, 68, 110, 136, 152 spécifications OSGi Compendium 16 Core 16 SPOF - Single Point Of Failure 116 Spring 15, 71, 75, 157 Spring IOC 70 Spring-DM 73, 130, 146 SpringSource 127 SQLite 150, 154, SRC 50 stratégie de bouchonnage 110 Swing 22 23, 101, 108, 150, 155 SWT 101 synchronized 81 T test unitaire 109, 111 durée 124 environnement d exécution 120 initialisation 120 TestNG , 124 Tomcat 100, 130 topic 93, 95 W WebConsole 71, 88 Websphere 17 X Xerial 158
29 Spécifications Core BundleContext Bundle Compendium httpservice LogService Implémentations Knopflerfish Equinox Felix Outils de développement bnd bndtools ipojo spring Outils d administration gogo Felix-stall Webconsole
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
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
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:...
Bien architecturer une application REST
Olivier Gutknecht Bien architecturer une application REST Avec la contribution de Jean Zundel Ce livre traite exactement du sujet suivant : comment faire pour que les services web et les programmes qui
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
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
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
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
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
TP1 : Initiation à Java et Eclipse
TP1 : Initiation à Java et Eclipse 1 TP1 : Initiation à Java et Eclipse Systèmes d Exploitation Avancés I. Objectifs du TP Ce TP est une introduction au langage Java. Il vous permettra de comprendre les
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]
Cours Plugin Eclipse. Université Paris VI / Parcours STL / Master I Pierre-Arnaud Marcelot - Iktek - [email protected]
Cours Plugin Eclipse Université Paris VI / Parcours STL / Master I Pierre-Arnaud Marcelot - Iktek - [email protected] 1 Qui suis-je? Ancien étudiant de Jussieu - Paris VI Diplomé du Master Technologies
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
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
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
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
Groupe Eyrolles, 2004 ISBN : 2-212-11504-0
Groupe Eyrolles, 2004 ISBN : 2-212-11504-0 Table des matières Avant-propos................................................ 1 Quel est l objectif de cet ouvrage?............................. 4 La structure
Formation Webase 5. Formation Webase 5. Ses secrets, de l architecture MVC à l application Web. Adrien Grand <[email protected]> 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
Expert technique J2EE
EHRET Guillaume 25, rue de la Richelandiere 42100 SAINT ETIENNE 32 ans - Célibataire Expert technique J2EE Domaines de compétences Environnement et langages Expertise en programmation Java et en architecture
Vérifier la qualité de vos applications logicielle de manière continue
IBM Software Group Vérifier la qualité de vos applications logicielle de manière continue Arnaud Bouzy Kamel Moulaoui 2004 IBM Corporation Agenda Analyse de code Test Fonctionnel Test de Performance Questions
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
INGÉNIEUR LOGICIEL JAVAEE / GROOVY 8 ANS D EXPÉRIENCE
INGÉNIEUR LOGICIEL JAVAEE / GROOVY 8 ANS D EXPÉRIENCE Igor Rosenberg 30 ans DEA «Image-Vision» de l Université de Nice Sophia-Antipolis POSTES PRECEDENTS MMA: Développement Web/Grails sur démonstrateur
Environnements de développement (intégrés)
Environnements de développement (intégrés) Introduction aux EDI, la plateforme Eclipse Patrick Labatut [email protected] http://www.di.ens.fr/~labatut/ Département d informatique École normale supérieure
Avant-propos. Le logiciel libre au service de la gestion
Avant-propos Depuis quelques années, l apport des systèmes d information à la compétitivité des entreprises est de plus en plus visible. D outils chargés de traiter des opérations répétitives, ces derniers
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
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
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
Glassfish dans le milieu médical. Sun Aquarium Paris 26 Juin 2009 Jacky Renno ([email protected])
Glassfish dans le milieu médical Jacky Renno ([email protected]) Plan Contexte Métier Technique Eléments structurants Approche Méthodologie et Outillage Choix de Glassfish Automatisation Industrialisation
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
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
La technologie Java Card TM
Présentation interne au CESTI La technologie Java Card TM [email protected] http://dept-info.labri.u-bordeaux.fr/~sauveron 8 novembre 2002 Plan Qu est ce que Java Card? Historique Les avantages
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
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
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
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é
Patrons de Conception (Design Patterns)
Patrons de Conception (Design Patterns) Introduction 1 Motivation Il est difficile de développer des logiciels efficaces, robustes, extensibles et réutilisables Il est essentiel de comprendre les techniques
SOA Open Source Intégration des services et business process dans une architecture SOA Open Source. Bruno Georges JBoss, a Division of Red Hat
SOA Open Source Intégration des services et business process dans une architecture SOA Open Source Bruno Georges JBoss, a Division of Red Hat Agenda Cas d etude Contexte métier Les bénéfices Open Source
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.
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
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
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
Hassene BELGACEM. Expériences Professionnelles. JEE architect / Technical leader. Ingénieur Informatique. Cycle Préparatoire
Objectifs Formations Expériences Professionnelles Hassene BELGACEM http://belgacem.hassene.netcv.com S intégrer dans une équipe de développement de haute compétence et participer activement dans la réalisation
Annexe : La Programmation Informatique
GLOSSAIRE Table des matières La Programmation...2 Les langages de programmation...2 Java...2 La programmation orientée objet...2 Classe et Objet...3 API et Bibliothèque Logicielle...3 Environnement de
Objectif : Passer de l analyse métier et fonctionnelle à la définition des applications qui
Formation PARTIE 1 : ARCHITECTURE APPLICATIVE DUREE : 5 h Objectif : Passer de l analyse métier et fonctionnelle à la définition des applications qui automatisent les fonctions Définir une architecture
Vulgarisation Java EE Java EE, c est quoi?
Paris, le 1 Février 2012 Vulgarisation Java EE Java EE, c est quoi? Sommaire Qu est ce que Java? Types d applications Java Environnements Java Versions de Java Java EE, c est quoi finalement? Standards
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
Sécurisation des architectures traditionnelles et des SOA
Sécurisation des architectures traditionnelles et des SOA Un livre blanc de Bull Evidian Gestion SAML des accès SSO aux applications classiques et J2EE. Max Vallot Sommaire Émergence des architectures
FileMaker Server 14. Guide de démarrage
FileMaker Server 14 Guide de démarrage 2007-2015 FileMaker, Inc. Tous droits réservés. FileMaker, Inc. 5201 Patrick Henry Drive Santa Clara, Californie 95054 FileMaker et FileMaker Go sont des marques
La reconquête de vos marges de manœuvre
La reconquête de vos marges de manœuvre Libérez vos applications critiques Bull ouvre de nouvelles portes à votre patrimoine applicatif. Bull LiberTP fait passer simplement vos applications transactionnelles
Constat ERP 20% ECM 80% ERP (Enterprise Resource Planning) = PGI (Progiciel de Gestion Intégré)
Constat Les études actuelles montrent que la proportion d'informations non structurées représente aujourd'hui plus de 80% des informations qui circulent dans une organisation. Devis, Contrats, Factures,
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
Projet de Java Enterprise Edition
Projet de Java Enterprise Edition Cours de Master 2 Informatique Boutique en ligne L objectif du projet de JEE est de réaliser une application de boutique en ligne. Cette boutique en ligne va permettre
Nouvelles technologies pour l intégration : les ESB
10, avenue de l Europe Parc Technologique du Canal 31520 Ramonville st Agne 05.61.28.56.20 05.61.28.56.00 www.ebmwebsourcing.com Nouvelles technologies pour l intégration : les ESB EBM Websourcing Sommaire
Famille IBM WebSphere Application Server
IBM Famille IBM Le socle applicatif qui répond à vos besoins métier Points clés Bâtir un socle solide et réduire les coûts avec un serveur d applications répondant à vos besoins métier Gagner en agilité
PRIMAVERA P6 ENTERPRISE PROJECT PORTFOLIO MANAGEMENT WEB SERVICES
PRIMAVERA P6 ENTERPRISE PROJECT PORTFOLIO MANAGEMENT WEB SERVICES DÉCOUVREZ DES POSSIBILITÉS ILLIMITÉES GRÂCE A L INTÉGRATION À DES SYSTÈMES D ENTREPRISE EXISTANTS FONCTIONNALITÉS Connectivité des systèmes
IBM Tivoli Compliance Insight Manager
Simplifier les audits sur la sécurité et surveiller les activités des utilisateurs privilégiés au moyen d un tableau de bord permettant de contrôler la conformité aux exigences de sécurité IBM Points forts
4. Utilisation d un SGBD : le langage SQL. 5. Normalisation
Base de données S. Lèbre [email protected] Université de Strasbourg, département d informatique. Présentation du module Contenu général Notion de bases de données Fondements / Conception Utilisation :
Prise en compte des ressources dans les composants logiciels parallèles
Prise en compte des ressources dans les composants logiciels parallèles Aperçus de l action RASC et du projet Concerto F. Guidec [email protected] Action RASC Plan de cet exposé Contexte Motivations
Repoussez vos frontières
Repoussez vos frontières Avec la plateforme d applications la plus rapide et agile au monde Vos applications métier disponibles tout le temps, partout. La Liberté de Choisir Client/Serveur - Applications
basée sur le cours de Bertrand Legal, maître de conférences à l ENSEIRB www.enseirb.fr/~legal Olivier Augereau Formation UML
basée sur le cours de Bertrand Legal, maître de conférences à l ENSEIRB www.enseirb.fr/~legal Olivier Augereau Formation UML http://olivier-augereau.com Sommaire Introduction I) Les bases II) Les diagrammes
Youssef LYHYAOUI Ingénieur Java/J2EE, SOA, ESB, Web services 31 ans Statut : Indépendant SITUATION ACTUELLE
Youssef LYHYAOUI Ingénieur Java/J2EE, SOA, ESB, Web services 31 ans Statut : Indépendant Adresse Personnelle : 3, allée du Roussillon 91300 Massy Téléphone : (+33) 06 78 37 34 82 E-mail : [email protected]
Solutions de gestion de la sécurité Livre blanc
Solutions de gestion de la sécurité Livre blanc L intégration de la gestion des identités et des accès avec l authentification unique Objectif : Renforcer la politique de sécurité et améliorer la productivité
Mettre en place une infrastructure Web nouvelle génération avec Drupal et Acquia
Mettre en place une infrastructure Web nouvelle génération avec Drupal et Acquia Pour l architecte de solutions web Table des matières Présentation générale... 3 Des outils disparates.... 4 Une gestion
Projet de développement
Projet de développement Introduction à Eclipse Philippe Collet Licence 3 MIAGE S6 2012-2013 http://miageprojet2.unice.fr/index.php?title=user:philippecollet/projet_de_développement_2012-2013 Plan r Application
Les Architectures Orientées Services (SOA)
Les Architectures Orientées Services (SOA) Ulrich Duvent Guillaume Ansel Université du Littoral Côte d Opale 50, Rue Ferdinand Buisson BP 699 62228 Calais Cedex Téléphone (33) 03.21.46.36.92 Télécopie
Programmer en JAVA. par Tama ([email protected]( [email protected])
Programmer en JAVA par Tama ([email protected]( [email protected]) Plan 1. Présentation de Java 2. Les bases du langage 3. Concepts avancés 4. Documentation 5. Index des mots-clés 6. Les erreurs fréquentes
Rapport de Synthèse. Création d un Générateur de modèle PADL pour le langage C++ Sébastien Colladon
L Y O N Département Informatique Année 2011/2012 Rapport de Synthèse Création d un Générateur de modèle PADL pour le langage C++ Sébastien Colladon Laboratoire Ptidej de L Ecole Polytechnique de Montréal
Cursus Sage ERP X3 Outils & Développement. Le parcours pédagogique Sage ERP X3 Outils et Développement
Cursus Outils & Développement Vous êtes Consultant, Chef de Projets, Directeur des Systèmes d Information, Directeur Administratif et Financier, Optez pour les «formations Produits» Nous vous proposons
Méthode de Test. Pour WIKIROUTE. Rapport concernant les méthodes de tests à mettre en place pour assurer la fiabilité de notre projet annuel.
Méthode de Test Pour WIKIROUTE Rapport concernant les méthodes de tests à mettre en place pour assurer la fiabilité de notre projet annuel. [Tapez le nom de l'auteur] 10/06/2009 Sommaire I. Introduction...
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
INTERSYSTEMS CACHÉ COMME ALTERNATIVE AUX BASES DE DONNÉES RÉSIDENTES EN MÉMOIRE
I N T E RS Y S T E M S INTERSYSTEMS CACHÉ COMME ALTERNATIVE AUX BASES DE DONNÉES RÉSIDENTES EN MÉMOIRE David Kaaret InterSystems Corporation INTERSySTEMS CAChé CoMME ALTERNATIvE AUx BASES de données RéSIdENTES
S T L - C P S - L e s p l u g i n s E c l i p s e. - Une Introduction - 2007, Frédéric Peschanski
S T L - C P S - L e s p l u g i n s E c l i p s e - Une Introduction - 2007, Frédéric Peschanski L a p l a t e f o r m e E c l i p s e Aperçu de la plateforme Eclipse Runtime Composants OSGI Equinoxe Plugins
IBM Tivoli Monitoring, version 6.1
Superviser et administrer à partir d une unique console l ensemble de vos ressources, plates-formes et applications. IBM Tivoli Monitoring, version 6.1 Points forts! Surveillez de façon proactive les éléments
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
Le Cloud Computing et le SI : Offre et différentiateurs Microsoft
Le Cloud Computing désigne ces giga-ressources matérielles et logicielles situées «dans les nuages» dans le sens où elles sont accessibles via Internet. Alors pourquoi recourir à ces centres serveurs en
Jean-Philippe VIOLET Solutions Architect
Jean-Philippe VIOLET Solutions Architect IBM Cognos: L' Expertise de la Gestion de la Performance Acquis par IBM en Janvier 08 Rattaché au Brand Information Management Couverture Globale 23,000 clients
Projet de développement. Introduction à Eclipse. Application à votre projet. Philippe Collet. Organisation. Cours 1 : principes généraux - svn
1 Organisation Projet de développement Introduction à Eclipse Philippe Collet Licence 3 Informatique Cours 1 : principes généraux - svn Cours 2 : Redmine et gestion de projet Cours 3 : Introduction à Eclipse
Java - la plateforme
Java - la plateforme Java la plateforme Java? VM GC JIT Java Aujourd'hui 3 environnements d'exécutions différents Java ME (Micro Edition) pour PDA, téléphone Android (Java SE moins certain paquetages)
Petit Déjeuner Pépinière du Logiciel Libre. 25 juin 2008
Petit Déjeuner Pépinière du Logiciel Libre 25 juin 2008 1 / 37 Agenda Définition & Principes Les différents outils & composants Les Solutions intégrés Open-Source Vos Questions 2 / 37 Agenda Définition
CQP Développeur Nouvelles Technologies (DNT)
ORGANISME REFERENCE STAGE : 26572 20 rue de l Arcade 75 008 PARIS CONTACT Couverture géographique : M. Frédéric DIOLEZ Bordeaux, Rouen, Lyon, Toulouse, Marseille Tél. : 09 88 66 17 40 Nantes, Lille, Strasbourg,
Magento. Magento. Réussir son site e-commerce. Réussir son site e-commerce BLANCHARD. Préface de Sébastien L e p e r s
Mickaël Mickaël BLANCHARD BLANCHARD Préface de Sébastien L e p e r s Magento Préface de Sébastien L e p e r s Magento Réussir son site e-commerce Réussir son site e-commerce, ISBN : 978-2-212-12515-3 Avant-propos
«clustering» et «load balancing» avec Zope et ZEO
IN53 Printemps 2003 «clustering» et «load balancing» avec Zope et ZEO Professeur : M. Mignot Etudiants : Boureliou Sylvain et Meyer Pierre Sommaire Introduction...3 1. Présentation générale de ZEO...4
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
Business Process Execution Language
Business Process Execution Language Rapport du projet de systèmes distribués d information Markus Lindström 6 mai 2009 Motivation personnelle Le sujet que j ai retenu et présenté dans le cadre du cours
Java au cœur de la base de données Oracle
32 Tips&techniques Philippe Daucourt, HEG Haute école de gestion Arc Java au cœur de la base de données Oracle Depuis la version 8i, Oracle embarque une machine virtuelle Java (JVM) au cœur de sa base
Architecture Orientée Service, JSON et API REST
UPMC 3 février 2015 Précedemment, en LI328 Architecture générale du projet Programmation serveur Servlet/TOMCAT Aujourd hui Quelques mots sur les SOA API - REST Le format JSON API - REST et Servlet API
La carte à puce. Jean-Philippe Babau
La carte à puce Jean-Philippe Babau Département Informatique INSA Lyon Certains éléments de cette présentation sont issus de documents Gemplus Research Group 1 Introduction Carte à puce de plus en plus
Industrialiser la chaîne complète de fabrication 1ère partie - Les bénéfices de la solution logicielle IBM VisualAge Pacbase / Rational
IBM Software Group Industrialiser la chaîne complète de fabrication 1ère partie - Les bénéfices de la solution logicielle IBM VisualAge Pacbase / Rational Fernard Bonaguidi [email protected]
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
Évaluation et implémentation des langages
Évaluation et implémentation des langages Les langages de programmation et le processus de programmation Critères de conception et d évaluation des langages de programmation Les fondations de l implémentation
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 [email protected] http://litis.univ-lehavre.fr/ duvallet/
Sécurisation du réseau
Sécurisation du réseau La sécurisation du réseau d entreprise est également une étape primordiale à la sécurisation générale de votre infrastructure. Cette partie a pour but de présenter les fonctionnalités
Gestion commerciale & marketing avec
Fabien Pinckaers Els Van Vossel Gestion commerciale & marketing avec Suivez vos prospects, dynamisez vos ventes, lancez des campagnes marketing! Adapté par Blandine Proust Groupe Eyrolles, 2012, pour la
as Architecture des Systèmes d Information
Plan Plan Programmation - Introduction - Nicolas Malandain March 14, 2005 Introduction à Java 1 Introduction Présentation Caractéristiques Le langage Java 2 Types et Variables Types simples Types complexes
DEMANDE D INFORMATION RFI (Request for information)
RFI-2013-09 Demande d information Page 1/9 DEMANDE D INFORMATION RFI (Request for information) Socle de Ged-Archivage SOMMAIRE 1. OBJET DE LA DEMANDE D INFORMATION... 3 2. PÉRIMÈTRE DE L INFORMATION...
ORACLE DATA INTEGRATOR ENTERPRISE EDITION - ODI EE
ORACLE DATA INTEGRATOR ENTERPRISE EDITION - ODI EE ORACLE DATA INTEGRATOR ENTERPRISE EDITION offre de nombreux avantages : performances de pointe, productivité et souplesse accrues pour un coût total de
XML, PMML, SOAP. Rapport. EPITA SCIA Promo 2004 16 janvier 2003. Julien Lemoine Alexandre Thibault Nicolas Wiest-Million
XML, PMML, SOAP Rapport EPITA SCIA Promo 2004 16 janvier 2003 Julien Lemoine Alexandre Thibault Nicolas Wiest-Million i TABLE DES MATIÈRES Table des matières 1 XML 1 1.1 Présentation de XML.................................
Programme scientifique Majeure ARCHITECTURE DES SYSTEMES D INFORMATION. Mentions Ingénierie des Systèmes d Information Business Intelligence
É C O L E D I N G É N I E U R D E S T E C H N O L O G I E S D E L I N F O R M A T I O N E T D E L A C O M M U N I C A T I O N Programme scientifique Majeure ARCHITECTURE DES SYSTEMES D INFORMATION Mentions
