
Apache Iceberg pour une architecture lakehouse sur AWS
Ce guide présente Apache Iceberg, un format de table moderne pour les données volumineuses, la gestion des versions et des performances optimisées.
Progression
Notre boîte de Leitner a fait peau neuve, et fonctionnellement, rien a changé ! Enfin.. Notre application est devenue une API, pour le bien de ce tutoriel, mais dorénavant, rien ne nous empêche de brancher d'autres types de Controller dans notre Infrastructure. Que l'on renvoit du JSON, de l'HTML, ou même qu'on branche des Commands à notre application pour interagir avec via le terminal, une chose est sûre: notre Domain n'en saura jamais rien, car il reste agnostique de toutes les couches au dessus de lui. C'est l'avantage de dépendre d'abstractions (interfaces) plutôt que d'implémentations concrètes.
Cela nous permet d'adopter une nouvelle façon de développer et d'ajouter des fonctionnalités: Toujours commencer par le Domain. Ce qui se passe au dessus ne devrait jamais être un problème tant que nos règles de gestions et le comportement de notre Domain n'a pas été ajouté. Puis on ajoute la couche Application pour orchestrer notre Domain. Si on a besoin de se connecter à la couche Infra pour une quelconque raison (base de donnée, envoit de mail, ...), alors on crée nos Interfaces dans le Domain, pour se concentrer sur ce que je dois faire plutôt que comment je le fais. Et je peux ajouter mes tests unitaires en isolation avec l'extérieur.
Enfin, quand tout cela est en place, je peux commencer à me demander comment j'implémente mes différentes interfaces, quel Mail Provider, quel type de base de donnée, quel Payment Provider, voire même quel Framework je veux brancher sur mon application. Et tout cela, c'est mon Infrastructure qui s'en charge.
Et voilà ! Je trouve cela beaucoup plus sain de se concentrer sur notre métier avant tout le reste, car c'est là la raison d'être de nos applications.
J'espère que ce tutoriel vous a plu et vous aura appris des choses, n'oubliez pas qu'il n'y a jamais une seule manière de faire, donc adaptez toujours ce que vous lisez à votre situation, votre équipe, et votre sensibilité.
Et pour terminer j'aimerais remercier Noel qui m'aura bien aidé lors mon auto-formation à la Clean Architecture, et sans qui ce tutoriel n'existerai pas !
Merci d'avoir suivi jusqu'ici et à très bientôt sur le blog d'Eleven Labs 👋
Auteur(s)
Arthur Jacquemin
Développeur de contenu + ou - pertinent @ ElevenLabs_🚀
Vous souhaitez en savoir plus sur le sujet ?
Organisons un échange !
Notre équipe d'experts répond à toutes vos questions.
Nous contacterDécouvrez nos autres contenus dans le même thème
Ce guide présente Apache Iceberg, un format de table moderne pour les données volumineuses, la gestion des versions et des performances optimisées.
Plongez dans le monde des AST et découvrez comment cette structure de données fondamentale révolutionne le développement moderne.
Retour sur les deux journées de conférences pour la SymfonyLive Paris 2025 à Paris.