Successfully reported this slideshow.
We use your LinkedIn profile and activity data to personalize ads and to show you more relevant ads. You can change your ad preferences anytime.

La Duck Conf : "Restructurer un legacy : comment et pourquoi ?"

153 views

Published on

Présentation du talk de Marc Bojoly - OCTO Technology
"En tant que programmeur, en tant qu’architecte nous voulons
tous partir d’une feuille blanche et construire quelque chose de
grand", nous dit sur son blog joelonsoftware.
Mais après 5 ans de développement en Java, est-ce pertinent ?
Est-ce le bon moment alors que le système doit absorber un
nouveau métier le plus vite possible ? Et si re-construire sur le
legacy était la solution pour réussir un tel défi ?

Published in: Technology
  • Be the first to comment

La Duck Conf : "Restructurer un legacy : comment et pourquoi ?"

  1. 1. #LaDuckConf by OCTO Technology © 2019 - All rights reserved
  2. 2. #LaDuckConf by OCTO Technology © 2019 - All rights reserved Restructurer son Legacy Marc BOJOLY 29 janvier 2019
  3. 3. #LaDuckConf by OCTO Technology © 2019 - All rights reserved Marc BOJOLY 3 Architecte senior et manager @mbojoly OCTO
  4. 4. #LaDuckConf by OCTO Technology © 2019 - All rights reserved 4 “We're programmers. Programmers are, in their hearts, architects, and the first thing they want to do when they get to a site is to bulldoze the place flat and build something grand.” www.joelonsoftware.com https://www.joelonsoftware.com/2000/04/06/things-you-should-never-do-part-i/
  5. 5. #LaDuckConf by OCTO Technology © 2019 - All rights reserved 5 “It’s harder to read code than to write it” www.joelonsoftware.com https://www.joelonsoftware.com/2000/04/06/things-you-should-never-do-part-i/
  6. 6. #LaDuckConf by OCTO Technology © 2019 - All rights reserved 6 “The single worst strategic mistake that any software company can make: They decided to rewrite the code from scratch.” www.joelonsoftware.com https://www.joelonsoftware.com/2000/04/06/things-you-should-never-do-part-i/
  7. 7. #LaDuckConf by OCTO Technology © 2019 - All rights reserved 7 Disclaimer : un retour d’expérience contextuel et orienté Ces solutions ne sont pas exhaustives, sont propres à ce contexte et à mes choix
  8. 8. #LaDuckConf by OCTO Technology © 2019 - All rights reserved 8 Disclaimer : un retour d’expérience contextuel et orienté Ces solutions ne sont pas exhaustives, sont propres à ce contexte et à mes choix Les choix de cette présentation Un focus sur l’architecture plus que sur l’organisation ou la testabilité.
  9. 9. #LaDuckConf by OCTO Technology © 2019 - All rights reserved 9 Disclaimer : un retour d’expérience contextuel et orienté Ces solutions ne sont pas exhaustives, sont propres à ce contexte et à mes choix Les choix de cette présentation Un focus sur l’architecture plus que sur l’organisation ou la testabilité. Un back-office assurance spécialisé dans le MRH.
  10. 10. #LaDuckConf by OCTO Technology © 2019 - All rights reserved 10 Disclaimer : un retour d’expérience contextuel et orienté Ces solutions ne sont pas exhaustives, sont propres à ce contexte et à mes choix Le rachat de 2 sociétés opérant le même métier d’assurance mais spécialisées dans la construction Les choix de cette présentation Un focus sur l’architecture plus que sur l’organisation ou la testabilité. Un back-office assurance spécialisé dans le MRH.
  11. 11. #LaDuckConf by OCTO Technology © 2019 - All rights reserved 11 Disclaimer : un retour d’expérience contextuel et orienté Ces solutions ne sont pas exhaustives, sont propres à ce contexte et à mes choix Le rachat de 2 sociétés opérant le même métier d’assurance mais spécialisées dans la construction Les choix de cette présentation Un focus sur l’architecture plus que sur l’organisation ou la testabilité. Un secteur très fortement contraint - Marges faibles limitant les capacités d’investissement - Clients concentrés pouvant imposer leurs choix Un back-office assurance spécialisé dans le MRH.
  12. 12. #LaDuckConf by OCTO Technology © 2019 - All rights reserved 12 Un enjeu métier et IT : partager une même application Application 1 MRH Application groupe 2013 AngularJS - Java - Progiciel EJB2 Application 2 Construction Rachat 1 Années 90 L4G Application 3 Construction Rachat 2 Années 2 000 VB.NET
  13. 13. #LaDuckConf by OCTO Technology © 2019 - All rights reserved 13 Construire sur l’existant MRH, tout ré-écrire, quelle alternative ? Référentiels Echanges et services externes Courrier Personnes EDI Légende Extranet Clients XXXXX XXXXX ClôtureXXXXX XXXXX Ouverture BI Reporting Données opérationnelles Documents Process Suivi Finance Comptabilité …
  14. 14. #LaDuckConf by OCTO Technology © 2019 - All rights reserved 14 Dans ce contexte, la ré-écriture n’est pas pertinente Référentiels Echanges et services externes Courrier Personnes EDI Légende Extranet Clients XXXXX XXXXX ClôtureXXXXX XXXXX Ouverture BI Reporting Données opérationnelles Documents Process Suivi Finance Comptabilité … NOUVEAUTÉ EVOLUTION EVOLUTION NOUVEAUTÉ EVOL EVOLUTION NOUVEAUTÉ EVOL UTIO N EVOLUTION EVOLUTION NOUVEAUTÉ EVOLUTION
  15. 15. #LaDuckConf by OCTO Technology © 2019 - All rights reserved 15 Le sentiment au début du projet Est-ce la bonne route ?
  16. 16. #LaDuckConf by OCTO Technology © 2019 - All rights reserved 16 Restructurer un legacy : ma définition Restructurer Un legacy Techniques obsolètes Difficulté de prise en main Connaissance faible voire erronée Absence de confiance
  17. 17. #LaDuckConf by OCTO Technology © 2019 - All rights reserved 17 Refactorer par petite touches Techniques obsolètes Difficulté de prise en main Connaissan ce faible voire erronée Absence de confiance
  18. 18. #LaDuckConf by OCTO Technology © 2019 - All rights reserved 18 Documentez Difficulté de prise en main Connaissance faible voire erronée Absence de confiance La documentation en informatique
  19. 19. #LaDuckConf by OCTO Technology © 2019 - All rights reserved 19
  20. 20. #LaDuckConf by OCTO Technology © 2019 - All rights reserved 20 En pratique https://www.thoughtworks.com/radar/techniques/lightweight-architecture-decision-records http://thinkrelevance.com/blog/2011/11/15/documenting-architecture-decisions
  21. 21. #LaDuckConf by OCTO Technology © 2019 - All rights reserved 21 Bilan au bout d’un an : l’impossible est en vue Apparition d’un domaine métier et premières réutilisations de code j’ai réalisé 80% de la documentation… mais les développeurs la mettent à jour et commencent à le faire de leur propre chef
  22. 22. #LaDuckConf by OCTO Technology © 2019 - All rights reserved 22 Comment ne pas refaire un legacy
  23. 23. #LaDuckConf by OCTO Technology © 2019 - All rights reserved 23 Comment ne pas refaire un legacy Techniques obsolètes Difficulté de prise en main Connaissance faible voire erronée Absence de confiance
  24. 24. #LaDuckConf by OCTO Technology © 2019 - All rights reserved 24 Comment ne pas refaire un legacy Technologie != Solution Simplifier Documenter l’intention Saisissez les opportunités
  25. 25. #LaDuckConf by OCTO Technology © 2019 - All rights reserved 25 Syndrôme du “+1 flux” Extranets Assureur Assuré X Y Schd tournées Exchange 360 Online
  26. 26. #LaDuckConf by OCTO Technology © 2019 - All rights reserved 26 Syndrôme du “+1 flux” Extranets Assureur Assuré X Y Schd tournées Exchange 360 Online
  27. 27. #LaDuckConf by OCTO Technology © 2019 - All rights reserved 27 Bâtir une façade Extranets Assureur Assuré X Y Schd tournées Exchange 360 Online Façade
  28. 28. #LaDuckConf by OCTO Technology © 2019 - All rights reserved 28 Eviter l’accumulation de complexité en la déplaçant Client 1 APIREST Client 3 EDI Client 2 EDI Client 1 ancienne version WS Emissaire intégration Application coeur de métier APIREST Référentiel d’entreprise Intégration
  29. 29. #LaDuckConf by OCTO Technology © 2019 - All rights reserved 29 Saisir les opportunités : exemple un décomissionnement Application X PDF Avant A décomissionner Application tablette PC Back X Téléchargement
  30. 30. #LaDuckConf by OCTO Technology © 2019 - All rights reserved 30 Pour ne pas réinjecter de la complexité là où elle est maximum Application X PDF Avant Après Application tablette Application S Back X Back S Téléchargement SSO
  31. 31. #LaDuckConf by OCTO Technology © 2019 - All rights reserved 31 Takeway final Refactorez par petite touche, de façon opportuniste Documentez les choix d’architecture Ne cédez pas aux sirènes de la technologie Construisez en dehors dès c’est pertinent Saisissez les opportunités pour construire l’avenir @mbojoly
  32. 32. #LaDuckConf by OCTO Technology © 2019 - All rights reserved 32 Sources ◉ https://www.joelonsoftware.com/2000/04/06/things-you-should-never-do-part-i/ ◉ https://pixabay.com/fr/bulldozer-v%C3%A9hicule-travailleurs-2038484/ ◉ https://pixabay.com/fr/les-%C3%AEles-artificielles-qatar-doha-3850752/ ◉ https://pixabay.com/fr/de-l-homme-main-soci%C3%A9t%C3%A9-papier-3131802/ ◉ https://pixabay.com/fr/l-architecture-plan-directeur-1857175/ ◉ https://gifer.com/en/GHD7 ◉ https://pixabay.com/fr/croix-rip-morts-mort-fun%C3%A9railles-159805/ ◉ https://pixabay.com/fr/montagne-glacier-neige-gamme-1209497 ◉ http://defense-92.fr/batiments/tour-first ◉ https://pixabay.com/fr/livre-poussi%C3%A9reux-oubliez-vieux-2803664/ ◉ https://www.jarchitect.com/ ◉ https://pixabay.com/fr/randonn%C3%A9e-d-hiver-montagne-enneig%C3%A9e-1796562/ ◉ https://pixabay.com/fr/site-crane-machines-de-construction-285645/ ◉ https://pixabay.com/fr/endroits-perdus-usine-hall-1495150/

×