Introduction
Après 3,5 mois de test de la version java de Googgle Appengine, j’arrive à la conclusion suivante : dans la version actuelle (Googgle Appengine SDK installé : la version 1.2.2), il est utopique de penser à migrer sans efforts des applications javaEE actuelles. La migration reste possible, n’est pas triviale.L’approche PaaS proposé par Google, dans son offre Googgle Appengine, ne privilégie pas la réutilisation des applications existantes pour trois raisons (contrairement à l'approche - à tester- de Spring sur son CloudFoundary).
- Une limitation des API java disponible et du ClassLoader (ce lien pour les classes du JRE et ce lien will-it-play-in-app-engine ?)
- - Une limitation des actions possibles (pas de gestion de thread, pas d’écriture dans des fichiers, …)
- - Un changement dans l’utilisation des bases de schémas possibles de bases de données
- Il est préférable que la première application déployée soit réécrite spécialement pour le Googgle Appengine. Cela permet de comprendre le modèle de programmation et le modèle de facturation, les performances … avant même de penser à la connecter aux autres applications Google.
Graisl & Groovy
Depuis sa version 1.1.1, Grails, est devenu le framework le plus prometteur de cette mouvance. Grails encapsule un condensé de Best practices, des meilleurs framewors (Spring, …) open source, des plugins spécifiques …Ce tutorial vous permet de saisir la faciliter de création et déploiement d’une application
Créer et déployer votre première application dans le cloud en10 commandes
Alors si vous souhaiter vous lancer dans le cloud en quelques minutes : adopter l’approche 3 G : Grails, groovy & Google Appengine.Les prérequis
- Java JDK installé (de préférence la dernière version )
- Grails installé : la version Grails 1.1.1
- Goggle Appenigne SDK installé : la version 1.2.2
- Avoir un compte Googgle Appenigne
Les étapes simplement (commades …)
- grails create-app my_First_3G_app
- cd my_First_3G_app
- grails uninstall-plugin hibernate
- grails install-plugin gorm-jpa
- grails install-plugin app-engine
- grails create-domain-class com.oxia.att.test.Message (ajouter un attribute message et faire le mapping JPA avec les annotations )
- grails generate-all com.oxia.att.test.Message (ajouter le code Groovy et GSP pour personaliser les écrans selon vos besoins)
- add to grails-app\conf\Config.groovy - google.appengine.application=" app3g "
- grails set-version 1
- grails app-engine deploy
Exemple de cette approche : http://np-grails.appspot.com/twitting/list
Pour tester localement l’application :
- grails app-engine
- go to http://localhost:8080 and test the app locally
Les étapes avec explications
Les étapes de 1 à 5 permettent de créer la structure de l’applicationCe qu’il faut retenir :
Ce qu’il faut retenir, Google appengine n’est pas compatible Hibernate, et que grâce au plugin Gorm-JPA de Grails, l’utilisation des annotations JPA est possible.Les étapes 8 à 10 : concernent le déploiement
Les étapes 6 et 7 concernent l’application Grails et le code métier, affichage …
L’application doit répondre, bien sûre, à vos besoins métiers, et correspondre à la charte graphique de votre entreprise.
Tous ses aspects peuvent être réalisés avec Grails / Groovy en respectant les limitations de Google app engine.
Espèrerons que la même application soit compatible avec l'offre de Spring sur son CloudFoundary.
Signalons, en fin, que la principale limitation qui va rencontrer votre projet : la définition de votre schéma de persistance (pour ne pas dire schéma SQL) compatible avec BigTable (ce n’est pas du SQL bien qu’on y accède en JPA ou JDO, dison GQL)
Mais ceci est un autre sujet
autres entrés sur le même sujet
0 commentaires :
Enregistrer un commentaire