Author Archives: Aurélien Pelletier

SOAP is the EJB of XML???

Le débat fait rage sur TheServerSide après une série de billets provocateurs par Carlos E. Perez:

SOAP is Comatose But Not Officially Dead!
More Nails For SOAP’s Coffin
Why REST is Better – Explained in Code

Je trouve la comparaison avec les EJB assez judicieuse. SOAP et les spécification WS-* sont bien trop ambitieuses et complexes (comme les EJB), on nous promet que tout sera simple grâce à des outils (comme les EJB) la pluspart des applications n’ont pas besoin de toutes ces fonctions avancées (comme les EJB) et il existe des alternatives (comme pour les EJB).

Effectivement en face les examples d’architecture REST (très bonne description, à lire) extrémement efficace sont nombreux (del.icio.us, flickr, yahoo…)

Un example qui me semble assez percutant de ce que l’on peut faire avec du REST (et un peu de XPath)

A quand la spécification WS-REST ???

Le problème avec SOA

Voici un bon billet parlant de SOA

“It strikes me that making this particular SOA dream a reality is not about specs nor is it about tools, it’s about modelling things in a different way such that all the problems of changing requirements etc do not have substantial interface impact”

Voilà, tout est dit, mettre en place une architecture orienté service ce n’est pas un problème technique mais fonctionnel. Une SOA c’est etre capable de définir des interfaces qui pourront être réutilisées alors que les spécifications des applications les utilisants vont évoluer.

Ca suppose que ces interfaces soient définies par quelqu’un qui connaisse extrémement bien le métier de l’entreprise.
Ca suppose que l’on dépasse la vision projet pour passer à une vision entreprise.
Ca suppose que l’entreprise ait au préalable une organisation bien structuré. Les services d’une SOA sont la modélisation du fonctionnement de l’entreprise, si l’entreprise fonctionne mal sans SOA elle ne fonctionnera pas mieux avec.

D’ailleur google ne s’y trompe pas, quand on chercher architecture orientée services on trouve cette très bonne description par mega

Le problème avec SOA

Voici un bon billet parlant de SOA

“It strikes me that making this particular SOA dream a reality is not about specs nor is it about tools, it’s about modelling things in a different way such that all the problems of changing requirements etc do not have substantial interface impact”

Voilà, tout est dit, mettre en place une architecture orienté service ce n’est pas un problème technique mais fonctionnel. Une SOA c’est etre capable de définir des interfaces qui pourront être réutilisées alors que les spécifications des applications les utilisants vont évoluer.

Ca suppose que ces interfaces soient définies par quelqu’un qui connaisse extrémement bien le métier de l’entreprise.
Ca suppose que l’on dépasse la vision projet pour passer à une vision entreprise.
Ca suppose que l’entreprise ait au préalable une organisation bien structuré. Les services d’une SOA sont la modélisation du fonctionnement de l’entreprise, si l’entreprise fonctionne mal sans SOA elle ne fonctionnera pas mieux avec.

D’ailleur google ne s’y trompe pas, quand on chercher architecture orientée services on trouve cette très bonne description par mega

EJB design patterns

J’avais besoin de me rafraichir un peu les idées sur le EJB command design pattern et maître google m’a dégôté une très bonne ressource. Un powerpoint de 116 slides qui explique assez en détail les différents design patterns utiles lorsque l’on fait (encore) des EJB:

EJB design patterns par  Vijay Bhatt

Un indispensable si vous devez faire des EJB.
Et oui, ils sont bons ces indiens…

Code et Commentaires

“Un code sans commentaire est un mauvais code,
un bon code n’a pas besoin de commentaire…”

Si je me souviens bien ça doit venir de The Pragmatic Programmer, une lecture hautement recommendable.

Je suis tombé sur ce billet qui illustre assez bien l’idée, plutôt que de mettre de tonne de commentaires dans le code pour respecter “les normes”, mieux vaux passer un peu de temps à refactorer son code pour qu’il n’y ait plus besoin de commentaire. Il est beaucoup plus dur (mais plus efficace aussi) de trouver les 3 mots qui vont former un nom de méthode explicite que de mettre 3 lignes de commentaires au dessus de doStuff().

Attention, je n’ai pas dis qu’il ne fallait pas de commentaires dans le code, mais juste la où il y en a vraiment besoin.