Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
Les microservices c'est pas automatique ! — DDD...
Search
Arnaud LEMAIRE
November 15, 2018
Programming
9
1.5k
Les microservices c'est pas automatique ! — DDD Paris 2018
La vidéo du talk est disponible :
https://youtu.be/_mqn0FfZ2SY
Arnaud LEMAIRE
November 15, 2018
Tweet
Share
More Decks by Arnaud LEMAIRE
See All by Arnaud LEMAIRE
Scaling in Three Dimensions – Data In Motion Paris 2024
lilobase
0
9
Intervention Michelin DORD
lilobase
0
52
The strategies behind ddd – AdeoDevSummit 2022
lilobase
6
1.3k
Let's reset Agile at Scale — Lean&Agile day Michelin 2022
lilobase
2
270
Sunday, retour d’expérience sur la construction d’une entreprise attractive pour les techs – Tech.rocks 2021
lilobase
1
130
Le projet legacy, quelles stratégies pour s'en sortir ? – Software Crafts·wo·manship Rennes juin 2021
lilobase
4
540
Réconcilier architecture logicielle & problématiques métiers : une introduction au Domain Driven Design – Blend Web Mix 2021
lilobase
5
1k
La qualité d’aujourd’hui est la productivité de demain — Orange Innovation School mars 2021
lilobase
1
550
Et si on redémarrait l'agile (à l'échelle) – Agile Niort 2021
lilobase
2
1.2k
Other Decks in Programming
See All in Programming
[PHPカンファレンス沖縄2024]「無理なくできるだけ安全に」テストもないレガシーコードをリファクタリングするテクニック
ikezoemakoto
3
110
NEWTにおけるiOS18対応の進め方
ryu1sazae
0
190
A Journey of Contribution and Collaboration in Open Source
ivargrimstad
0
180
pytest プラグインを開発して DRY に自動テストを書こう
inuatsu
2
250
Micro Frontends for Java Microservices - dev2next 2024
mraible
PRO
0
190
Kubernetes上でOracle_Databaseの運用を楽にするOraOperatorの紹介
nnaka2992
0
150
Remix × Cloudflare Pages × Sentry 奮闘記 / remix-pages-sentry
nkzn
1
370
NANIMACHI
naokiito
0
930
Интеграционное тестирование: как приручить хаос
mariyasaygina
0
500
Quarto Clean Theme
nicetak
0
220
AWS CDKを用いたセキュアなCI/CDパイプラインの構築 / Build a secure CI/CD pipeline using AWS CDK
seike460
PRO
3
560
推しの夫に恋のGPS「ときメーター」#M5Stack #IoT #M5JPTour2024
riyu
0
220
Featured
See All Featured
Let's Do A Bunch of Simple Stuff to Make Websites Faster
chriscoyier
504
140k
Thoughts on Productivity
jonyablonski
67
4.2k
ParisWeb 2013: Learning to Love: Crash Course in Emotional UX Design
dotmariusz
109
6.9k
ReactJS: Keep Simple. Everything can be a component!
pedronauck
663
120k
Put a Button on it: Removing Barriers to Going Fast.
kastner
58
3.5k
jQuery: Nuts, Bolts and Bling
dougneiner
61
7.5k
In The Pink: A Labor of Love
frogandcode
139
22k
Testing 201, or: Great Expectations
jmmastey
38
7k
The Straight Up "How To Draw Better" Workshop
denniskardys
231
130k
What's new in Ruby 2.0
geeforr
341
31k
I Don’t Have Time: Getting Over the Fear to Launch Your Podcast
jcasabona
26
1.9k
Infographics Made Easy
chrislema
239
18k
Transcript
DISCLAIMER ! Tout doit être nuancé en fonction de votre
contexte ! Ce Talk contient de la mauvaise foi
Les microservices, l’homéopathie au service de l’architecture logicielle ?
LES MICROSERVICES, C’EST PAS AUTOMATIQUE… Arnaud LEMAIRE | @lilobase LGO.GROUP
Vous êtes une startup en train de définir votre produit
? « On a pas encore notre product/market fit, mais faut bien s’occuper »
DON’T Et puis, vous n’êtes pas assez nombreux… Et vous
ne savez même pas quel est votre métier « Vous achetez des problèmes que vous n’avez pas les moyens de résoudre »
Le problème Généralement on ne réussit pas à modéliser le
métier correctement du premier coup Avoir un code source co-localisé & une seule unité de déploiement simplifie grandement le refactoring
Oui, mais on doit monter en charge / avoir de
la haute dispo
SRSLY ? Vous pouvez même créer plusieurs main pour spécialiser
vos instances Vous ne pouvez pas démarrer plusieurs instances de votre applicatif ?
Le problème Avoir un cluster du même acteur nécessite de
les synchroniser pour éviter les problèmes de consistance Tuyaux intelligents, consensus (RAFT), Lock distribué …
Oui, mais on est en train de scaler ! «
On a recruté 60 personnes en trois mois et il faut bien les occuper »
Wait… ! Recruter ou produire, il faut choisir !
Grandir ou produire, il faut choisir !
OK, but… Faites gaffe aux frontières ! Et ne faites
pas des « micro » services, juste des applications qui parlent ensemble… Mais vous avez quand même le droit de dire aux copains que vous faites du microservice !
Service A API Le problème Service B
External API Service A La solution Service B Internal API
Anti-corruption Layer
On veut pouvoir utiliser plusieurs langages ! « Il faut
avouer que l’on arrive plus à recruter avec notre stack Struts »
Wait… ! Est-ce vous n’êtes pas en train de faire
du CV Driven Development ? Les microservices vont vraiment être une solution ?
Le problème Vous risquez de créer des silos par techno
Et est-ce que ce langage corrige vraiment des problèmes que vous avez ?
On a des besoins d’orchestrations spécifiques… « Chez nous c’est
vraiment différent de chez les autres »
Example Counter Ice Cream Hamburgers Salads New Order ——
—— —— New Order —— —— —— New Order —— —— ——
Example Counter Ice Cream Hamburgers Salads
Counter Ice Cream Hamburgers Salads Each time we receive an
item, we check if the order is complete. New Order —— —— —— Example
Wait… ! Agent Acteur
Wait… ! Orchestration Choreography
Counter Ice Cream Hamburgers Salads C’est une orchestration d’agents !
New Order —— —— —— Example
Wait… ! C’est toujours pas des microservices… Ça peut se
déployer dans la même JVM/CLR…
Le projet de la refonte du monolithe Legacy
Wait… ! « If you can’t build a monolith, what
makes you think micro-services are the answer ? » -Simon Brown
Monolith Microservices -Alvaro Sanchez
Wait… ! « Organisations which design systems ... are constrained
to produce designs which are copies of the communication structures of these organisations. » -Melvin Conway
-Simon Brown
-Simon Brown
-Simon Brown 1 2
Facade Parent Injector S1 S2
Facade Parent Injector S1 HTTP connector
On a une hétérogénéité des métiers, des modèles de déploiement,
d’architecture & d’exécution
OK, but… Bienvenue en enfer ;-) Transactions distribuées, Consistance
à terme, Tolérance à la panne, Auditabilité & Traçabilité, Déliverabilité… Et puis ça apparait pas tout de suite
NE MÉLANGEONS PAS TOUT…
• Modèle d’adressage : Agent / Acteur • modèle d’exécution
• Request/Response, Pub/Sub, Queue • Push vs Pull • Modèle d’Orchestration ou Chorégraphie • Modèle de déploiement • Tooling…
« Big Data is like teenage sex: everyone talks about
it, nobody really knows how to do it, everyone thinks everyone else is doing it, so everyone claims they are doing it… » – Dan Ariely Micro-service
MANY THANKS ! Arnaud LEMAIRE | @lilobase LGO.GROUP