mercredi 29 juillet 2009

Microsoft-Yahoo Vs Google : La guerre des moteurs ou la recherche moteur de la guerre

En ce mois de juillet 2009, un accord, pour sauver les bénéfices de Yahoo, en chute libre depuis quelques mois

Enfin, un accord de 10 ans pour mettre sur les rails le nouveau moteur de recherche de Microsoft BING (et à dieu msn).

Enfin un accord sur les rôles : Microsoft pour la technologie recherche et Yahoo pour la gestion des annonces.

Un accord entre le numéro 2 et numéro 3,

Bing-yahoo est désormais le numéro 2 de la recherche sur le web

Une alternative sérieuse pour les annonceurs face à l’hégémonie de Google dans le domaine de la publicité en ligne.

Quelle serait la réaction du coté de Google ?

et ne me dites pas qu'il a encore deux ans devant lui avant que la fusion des technlogies de Bing et yahoo ne soient effectives.

Google, a déjà lancé des attaques frontales avec Microsoft sur les thèmes de : cloud et Google AppEngine, les appstore, les OS, les navigateurs, les suite bureautique, les outils collaboratives (Wave, messagerie en ligne, messagerie instantanée, Plateform de blog, wiki ..) … Google cherche à mener ses batailles sur le terrain de l’enemi,

Le voilà, attaqué sur son propre terrain, Il va falloir relire les conseils de Sun Tzu.

Rappelons que la guerre est aussi lancée sur le front de la présentation des résultats: trop tabulaire, trop classique, peu précise.

Nous entendons de plus parler de "fact engine" à la place de "search engine",

Ça me rappelle une ancienne bloque sur le CNRS : « on y trouve des chercheurs on, mais on cherche des, toujours, des trouveurs» ..

C’est ce que propose Goggle Squared ou le tout nouveau Walfram Alpha (créateur Matimatica de mon application préféré, lorsque je travaillais sur le théorie du chaos et la modélisation des phénomènes non linaires…, bref le bon vieux temps).

clip_image001

clip_image003

Walfram Alpha est supposé comprendre des questions formulés en langage naturel, il peine à le faire pour le moment, mais espérons qu’il réussisse.. ;

clip_image004

Goggle Squared propose ce type d’information (copié souvent chez Wekipedia)

clip_image006

Car, s’il devient vraiment performant, le moteur de recherche deviendra Le vrai assistant personnel, un moteur d’aide à la décision, de l’internaute : qui l’assistera à explorer, chercher, et trouver ce qu’il souhaite…

Suite à ce rapprochement, il reste une question à régler : à qui appartiendra les données sur le comportement des internautes ?

Mais, ceci est un autre sujet

mardi 28 juillet 2009

Mule version 2.x & JMS : comment enlever les header des messages

Mule simplifie l’intégration des systèmes en faisant abstraction des protocoles de transport.

Il est très simple de lire à partir d’une file d’attente un message et de l’envoyer vers un fichier ou vers un web service (appeler un web service et lui passer comme argument le message lu dans la file d’atetnte, sans ou avec une transformation).

Créer un pont entre un webservice est une file d’attente est aussi simple : quelques lignes de configruation : Inbound – composant – outbound

Mais, il arrive que lorsqu’on essaye de persister un message obtenu par appel à un web service, dans une file d’attente JMS, d’obtenir ce type message


Header: Accept-Charset is not compliant with JMS specification (sec. 3.5.1, 3.8.1.1). It will cause problems in your and other applications. Please update your application code to correct this. Mule renamed it to Accept_Charset

Header: Accept-Encoding is not compliant with JMS specification (sec. 3.5.1, 3.8.1.1). It will cause problems in your and other applications. Please update your application code to correct this. Mule renamed it to Accept_Encoding

Header: Accept-Language is not compliant with JMS specification (sec. 3.5.1, 3.8.1.1). It will cause problems in your and other applications. Please update your application code to correct this. Mule renamed it to Accept_Language

Header: Cache-Control is not compliant with JMS specification (sec. 3.5.1, 3.8.1.1). It will cause problems in your and other applications. Please update your application code to correct this. Mule renamed it to Cache_Control

Comment enlever ce warning ?

Très simple

Appliquer un transformateur spécial offert par Mule

Le <message-properties-transformer …>

1:    <message-properties-transformer name="NettoyeurDeMessageProperties">
2: <delete-message-property key="Accept-Charset" />
3: <delete-message-property key="Accept-Encoding" />
4: <delete-message-property key="Accept-Language" />
5: <delete-message-property key="Cache-Control" />
6: </message-properties-transformer>




il est possible de créer votre propre transformer …

mais ceci est un autre sujet

-------------------------------

autres sujets sur Mule



  • Mule ESB : le routeur outbound-pass-through-router a changé de nom entre la version 2.0 et 2.1 ..


  • Fonctionnalités des ESB et offre open source : le marché n’est pas encore consolidé


  • http://net-progress.blogspot.com/2009/07/mule-version-2x-jms-comment-enlever-les.html

    Rappel : Mule est un 'java software' assimilable à un ESB
  • lundi 20 juillet 2009

    Mule ESB : le routeur outbound-pass-through-router a changé de nom entre la version 2.0 et 2.1 ..

    Le routeur « pass-through router » est conçu pour simplement passer des messages à partir d'une extrémité (Endpoint dans le jargon de Mule) à l'autre. Ceci est utile pour l'envoi des messages à une file d'attente, par exemple.


    Vous pouvez utiliser le routeur « pass-through router » pour «réaliser » un pont ou une passerelle entre deux protocoles (envoi vers un autre Outbound).

    Mule expose une implémentation simple de « pass-through router », mais attention cette version a changé entre la version 2.0 et 2.1 de Mule

    Mule Version 2.0

    1: <outbound>
    2: <outbound-pass-through-router>
    3: <vm:outbound-endpoint path="rep.in" />
    4: </outbound-pass-through-router>
    5: </outbound>


    Mule Version 2.1 (pass-through-router à la place de outbound-pass-through-router)



    1: <outbound>
    2: <pass-through-router>
    3: <vm:outbound-endpoint path="rep.in" />
    4: </pass-through-router>
    5: </outbound>


    D‘autres Routeur (au sens EIP du mot ) existe dans Mule, mais ceci est un autre sujet



    autres sujets sur Mule



  • Mule ESB : le routeur outbound-pass-through-router a changé de nom entre la version 2.0 et 2.1 ..


  • Fonctionnalités des ESB et offre open source : le marché n’est pas encore consolidé

  • http://net-progress.blogspot.com/2009/07/mule-version-2x-jms-comment-enlever-les.html


  • Rappel : Mule est un 'java software' assimilable à un ESB

    samedi 18 juillet 2009

    Jbpm 4 Tutorial : JBPM 4 a simplifié son modèle de programmation et a confirmé l’orientation BPMN


    Une statistique économique stipule que la mortalité enfantine (moins de 5 ans d’existence) des entreprises est à 80 %.

    Or JBPM a plus de 5 ans, il a passé l’âge difficile de l’enfance, il est très populaire, et son père d’adoption s’appelle RedHat (prioritaire de Jboss) : C’est pour cette raison, qu’il se reconstruit, et se permet de prendre le risque de tout changer : modèle de programmation et schéma de base de données.

    Son objectif: simplifier le modèle de programmation, pour augmenter le nombre d’adoption.

    Rappelons que JBPM est le moteur de workflow (il veut qu’on dise BPM) le plus populaire de la communauté java. Il est embarqué, ou utilisé, dans plusieurs produit :; de Mule à Intalio en passant par Liferay, Alfresco et le fameux Exo Platform (dont le portail est devenu, depuis peu, Jboss Exo Portal, avec un grand avenir en perspective).

    Notons que l’équipe d’Exo Platform a fait le choix de JBPM, comme moteur de workflow longtemps avant de fusionner avec Jboss (bien que le consortium ObjectWeb, OW2, dont Exo fait partie, en possède un : Bonita).

    Jbpm 4 arrive pour renforcer le basculement vers le PVM (Processs Virtual Machine), concept un peu flou, mais qui est promu par RedHat.

    Modèle de programmation remanié

    Cette version 4 de JBPM est une réécriture complète de la version 3 : tout en conservant les principes de bases : 100% java, notion de processus, stockage des instances et des définitions des processus ans la base de données, basé sur Hibernate, assisté par un IDE.

    Beaucoup d’utilisateurs de Jbpm 3 seront d'accord avec moi que certaines API étaient difficile à certains endroits et qu’il fallait écrire de complexes requêtes Hibernate conduisant à plusieurs problèmes:

    Le mélange de concepts dans les API de JBPM3 faisait qu’on trouvait des méthodes éparpillés dans les classes JbpmContext, GraphSession ou TaskManagement.

    L’équipe JBPM 4 a rationalisé cela autour de la l’API ProcessEngine.

    N’importe quelle utilisation de JBPM commence par acquérir les services souhaités à partir de ProcessEngine : le nœud centrale du BPM selon RedHat.

    Ensuite on utilise l’API selon le besoin

  • RepositoryService: permet de gérer les données statiques des processus : déploiement, activation / désactivation, requête.. ;.

  • ExecutionService: expose des opérations d’exécution runtime (concernant les instances de processus): lancer l’exécuter des instances de processus, gérer les variables, récupérer les instances pour faire avancer le processus ou l’effacer, etc.

  • TaskService: il s’(agit de la modélisation de l’interaction humaine: tout ce qu’on sohiate faire avec des tâches : créer, rechercher, assigner, compléter .
  • clip_image002

    Deux autres API ont fait leurs apparitions :

  • HistoryService: dans jBPM4, il y a eu une séparation claire et nette entre le runtime et les données historisations. Ce service présente des mesures et calcules statistiques réalisé par le moteur. L’API HistoryService n’a aucune relation avec le moment : elle traite de l’histoire et des temps passés. A travers ce service les données historique (instances terminée, activité exécutés) peuvent être recherché et présentés pour une étude statistique ultérieure.

  • ManagementService: cette API est destine aux outils de gestion de processus telque la fameuse console JBPM.
  • Schéma de la base de données simplifié

    le schéma de la base de donnée de JBPM 4 est simplifié par rapport à la version 3.x:

    clip_image001

    clip_image002[5]

    Et le mapping Hibernate est le suivant

          <mapping resource="jbpm.repository.hbm.xml" />
    <mapping resource="jbpm.execution.hbm.xml" />
    <mapping resource="jbpm.history.hbm.xml" />
    <mapping resource="jbpm.task.hbm.xml" />
    <mapping resource="jbpm.identity.hbm.xml" />








    Exemple simple : exécuter un processus JBPM4






    Un premier test de la nouvelle mouture de JBPM : la version 4 de JBPM



    Il s’agit d’un simple exemple de processus contenant deux étapes : une permettant d’afficher un message et l’autre de lancer un backup



    JBPM 4 utilise la notation BPMN 2.0









    clip_image004






    La version XML de cette définition du processus :






     <?xml version="1.0" encoding="UTF-8"?>
    <process name="seconde_hello_de_OXIA" xmlns="http://jbpm.org/4.0/jpdl">
    <start g="24,72,80,40">
    <transition to="afficherMessage"/>
    </start>
    <java class="com.oxia.att.jbpm4.exemple.AfficherMessage" g="120,68,138,56" method="afficherMessage" name="afficherMessage">
    <transition to="lancerBackup"/>
    </java>
    <end g="165,267,80,40" name="fin"/>
    <state name="lancerBackup" g="143,147,92,52">
    <transition name="to fin" to="fin" g="-30,-18"/>
    </state>
    </process>


    La classe java de traitement de l’affichage






     package com.oxia.att.jbpm4.exemple;
    public class AfficherMessage {
    public void afficherMessage() {
    System.out.println("****** début de passage par un Etat");
    System.out.println(" Bonjour de OXIA!");
    System.out.println("****** fin de passage par un Etat ");
    }
    }


    Pour tester ce processus dans un projet Java (simple)






     public static void main(String[] args) {
    // obtenir une instance de ProcessEngine avec la
    // configuration souhaitée oxia.att.jbpm.cfg.xml
    ProcessEngine processEngine = new Configuration().setResource("oxia.att.jbpm.cfg.xml").buildProcessEngine();
    // obtenir une instance de RepositoryService
    RepositoryService repositoryService = processEngine.getRepositoryService();
    // Deployer la définition du processus first_Jbpm_Sample.jpdl.xml
    repositoryService.createDeployment().addResourceFromClasspath("com/oxia/att/jbpm4/exemple/first_Jbpm_Sample.jpdl.xml").deploy();
    // obtenir une instance de ExecutionService
    ExecutionService executionService = processEngine.getExecutionService();
    ProcessInstance processinstance = executionService.startProcessInstanceByKey("hello_de_OXIA");
    System.out.println( processinstance.getId());
    System.out.println( processinstance.getState());
    }


    Le résultat






     ****** début de passage par un Etat
    Bonjour de OXIA!
    ****** fin de passage par un Etat
    hello_de_OXIA.6
    ended


    Conclusion






    RedHat a restructuré JBPM 4 autour d’une API claire et un schéma de base de données efficace.






    Reste à vérifier les annonces concernant l’amélioration des performances : grâce au nouveau schéma de base de données, la récriture des classes de bases de Job executor et activities et l’amélioration de la gestion de la concurrence.









    Quelques reproches pour le moment, l’obligation d’aller dans le repository SVN pour constituer les war de la console et la qualité médiocre de l’IDE (pas possible de créer un projet JBPM 4, amis seulement type 3)






    clip_image006









    Mais ceci est un autre sujet






    Autre sujets









    1. Un peu de monitoring Métier (BAM) avec JBPM et SeeWhy (event-driven business intelligence )



    2. Comment modéliser un processus métier avec JBPM : exemple “gestion des entretiens”



    3. Quelle est la différence entre JBPM et Intalio ?



    4. Graph Oriented Programming (GOP) avec JBPM



    5. BPM & Moteur de workflow : l’offre open source



    6. La version 4 de JBPM prend le virage de BPMN



    7. Jbpm 4 Tutorial : JBPM 4 a simplifié son model de programmation et a confirmé l’orientation BPMN








  • Architecte SOA & Professionnel Open Source Headline Animator

     
    Khaled BEN DRISS
    Cloud Computing, SOA et Web 2.0 : Des sujets techniques sur SOA et l'Open Source : de Java & .Net, PHP5, Symfony, à SaaS / PaaS en passant par Azure, google appengine, le BPM, la Modélisation et d'autres sujets du coté du serveur et cloud computing.