Ingénierie de plate-forme vs DevOps : ce que vous devez savoir
L’ingénierie de plate-forme est le processus de conception et de mise en œuvre de chaînes d’outils qui améliorent l’expérience de livraison de logiciels. Les ingénieurs de plateforme mettent en place une infrastructure automatisée et des contrôles en libre-service qui permettent aux développeurs de travailler plus efficacement.
L’ingénierie de plate-forme est une évolution de DevOps. DevOps définit des principes pour rationaliser le développement en utilisant l’automatisation, l’autonomie et la collaboration. Ces qualités font également partie intégrante de l’ingénierie de la plate-forme, de sorte que la technique vous aide à obtenir de bonnes performances DevOps.
Sommaire
Comprendre DevOps
DevOps rapproche les équipes de développement et d’exploitation. Il se concentre sur l’utilisation d’outils, de systèmes et de processus itératifs pour raccourcir les cycles de rétroaction. Les stratégies DevOps réussies accélèrent le débit de votre équipe sans compromettre la qualité.
DevOps est un concept ouvert. Différentes organisations combineront des ensembles uniques d’outils et de méthodologies pour créer leur propre mise en œuvre. Cependant, l’accent mis sur le débit, la qualité et l’unification du développement et des opérations est une caractéristique constante dans toutes les organisations.
Le développement et les opérations étaient traditionnellement gérés par des équipes distinctes sans canal de communication direct. Les développeurs ont écrit le code pendant que les opérateurs provisionnaient l’infrastructure, lançaient les déploiements et surveillaient les problèmes. Ce modèle ne peut pas s’adapter à l’échelle des applications modernes, qui peuvent comprendre des centaines de microservices indépendants. Les développeurs ont besoin d’un accès en libre-service à des environnements similaires à la production afin de pouvoir tester de nouveaux composants dans un cadre réaliste. C’est là qu’intervient l’ingénierie de plate-forme.
Le rôle de l’ingénierie de plate-forme
Les équipes d’ingénierie de plateforme sont chargées d’établir des outils et des processus qui aident les développeurs à être plus productifs. Ils conçoivent la « plate-forme » sur laquelle les développeurs construisent. En pratique, les ingénieurs de plate-forme effectuent souvent les tâches suivantes :
- Infrastructure de provisionnement telle que des environnements de staging, des pipelines CI et des systèmes de test automatisés à utiliser par les développeurs.
- Création d’API et de processus internes pour suivre l’état des modifications et automatiser les déploiements.
- Liaison avec l’équipe des opérations pour s’assurer que l’infrastructure de développement correspond exactement à la production.
- Mettre en œuvre des mesures de sécurité, de fiabilité et de conformité qui identifient le code problématique avant qu’il ne soit fusionné.
- Fournir des contrôles en libre-service autour de ce qui précède, afin que les développeurs puissent créer des environnements de test, exécuter des tests et effectuer des audits de sécurité à la demande, sans attendre les autres équipes.
Ce travail produit une plate-forme qui réduit la charge de travail des développeurs. Les parties périphériques fastidieuses de la livraison de logiciels sont transférées sur la plate-forme gérée, ce qui permet aux ingénieurs de se concentrer sur la création de nouvelles fonctionnalités. L’équipe peut continuer à avancer, en expédiant plus de code aux clients dans le cadre des garanties de la plate-forme.
Les rôles d’ingénierie de plate-forme dédiée ne se trouvent généralement que dans les grandes organisations. Vous avez besoin d’un pool suffisamment important d’ingénieurs disponibles avant de pouvoir en dédier certains à la construction de plateformes internes. Cependant, les petites équipes peuvent toujours bénéficier du modèle d’ingénierie de plate-forme. À l’état pur, l’ingénierie de plate-forme consiste simplement à optimiser votre environnement de développement. Essayez d’allouer quelques heures par semaine à la création d’outils et de processus qui résolvent les goulots d’étranglement de votre flux de travail.
Les meilleures plateformes internes se comportent un peu comme une solution PaaS privée. Ils regroupent toutes les fonctionnalités dont les développeurs ont besoin dans des interfaces pratiques telles que les CLI, les interfaces utilisateur Web et les pipelines automatisés. La plate-forme réduit les frais généraux de création de logiciels afin que les développeurs puissent se concentrer sur le code. Cela réduit la distraction, diminue la charge cognitive et facilite des habitudes de travail plus productives.
Comment l’ingénierie de plate-forme a-t-elle émergé ?
L’ingénierie des plates-formes est apparue à la suite de la complexité croissante des applications modernes. De nos jours, les applications sont généralement formées de plusieurs composants faiblement couplés qui s’exécutent dans des environnements distribués. Le provisionnement et la maintenance de l’architecture peuvent être une procédure en plusieurs étapes qui nécessite des connaissances spécialisées.
Les développeurs sont principalement concernés par l’écriture de code qui active de nouvelles fonctionnalités commerciales. La tâche de gérer la plate-forme appartient aux opérations. Bien que DevOps rapproche les deux, il peut être irréaliste de s’attendre à ce que des développeurs individuels soient capables de déployer l’intégralité de la pile lorsqu’ils ont besoin d’un nouvel environnement de test. Dans certaines industries réglementées, cela pourrait même être interdit par des contrôles de conformité.
L’ingénierie de plate-forme résout le problème en offrant aux développeurs un accès en libre-service à des environnements gérés par une équipe dédiée. Les développeurs peuvent cesser de se soucier de l’infrastructure, des pipelines et des scripts de construction qui ne relèvent pas de leurs descriptions de travail. Les chefs d’entreprise et le personnel de conformité peuvent se détendre en sachant que tous les environnements sont créés de manière standardisée.
Ingénierie de plate-forme vs DevOps
L’ingénierie de plate-forme est mieux considérée comme une progression logique de DevOps. C’est une approche concrète que vous pouvez utiliser pour maximiser le succès de DevOps. La résolution des points faibles des développeurs augmentera le débit et offrira de nouvelles opportunités pour mettre en place des protections autour de votre code.
L’ingénierie de la plate-forme accorde aux développeurs l’autonomie afin qu’ils puissent accéder aux outils à la demande, sans attendre leurs collègues ni effectuer eux-mêmes des tâches fastidieuses. Il s’appuie fortement sur l’automatisation et forme un pont avec les opérations, répondant à deux autres principes DevOps. Aider votre équipe produit principale à se concentrer sur de nouvelles fonctionnalités commerciales est un moyen garanti de réduire vos délais et de devenir plus réactif aux demandes des clients.
DevOps est bien plus qu’une simple ingénierie de plate-forme. Vous aurez toujours besoin d’autres outils et processus pour soutenir vos équipes, de l’idée à la production. L’ingénierie de plate-forme est un composant centré sur le développeur dans la stratégie DevOps, mais d’autres éléments tels que le travail lean, l’adhésion de l’équipe et l’observabilité détaillée ne sont pas moins importants.
Ingénierie de plateforme et SRE
L’ingénierie de fiabilité de site (SRE) est souvent abordée dans le contexte de DevOps et de l’ingénierie de plate-forme. Les équipes SRE sont chargées de maintenir la fiabilité de vos services. Ils utilisent des objectifs au niveau de l’entreprise tels que les SLO, les SLA et les marges d’erreur pour identifier quand le service s’écarte des attentes des utilisateurs. Cela devrait inciter les équipes d’ingénierie à arrêter de travailler sur de nouvelles fonctionnalités et à privilégier les améliorations de stabilité à la place.
Les équipes de plate-forme chevauchent souvent les ingénieurs SRE. Les deux rôles fournissent et maintiennent des environnements logiciels à l’aide de l’automatisation. Il y a cependant une différence significative dans l’intention. Alors que SRE se concentre sur la satisfaction constante des besoins des utilisateurs, l’ingénierie de plate-forme consiste à satisfaire les besoins des développeurs. Bien que vous deviez prêter attention aux deux domaines, l’ingénierie de plate-forme est généralement moins prioritaire que SRE.
Un pipeline défectueux dans une plate-forme de développement sera gênant, entraînant des retards dans votre processus DevOps, mais cela ne devrait pas affecter vos utilisateurs finaux. C’est un problème pour l’ingénierie de plate-forme. Cependant, SRE devra s’impliquer si un serveur de production se déconnecte ou ralentit, car l’incident aura un impact direct sur les utilisateurs.
Sommaire
L’ingénierie de plate-forme accélère la livraison de logiciels en offrant aux développeurs des outils en libre-service pour interagir avec l’infrastructure. Les équipes d’ingénieurs utilisent la plate-forme fournie pour tester rapidement le nouveau code et le déployer dans tous les environnements.
DevOps et l’ingénierie de plate-forme sont des sujets étroitement liés. L’ingénierie de plate-forme est généralement mise en œuvre dans le cadre d’une stratégie DevOps. Il augmente l’autonomie des développeurs et automatise les tâches d’infrastructure banales, en respectant les principes fondamentaux de DevOps.
Il est possible de faire du DevOps sans ingénierie de plate-forme. De même, vous utilisez peut-être déjà des outils et des processus qui relèvent de la bannière de l’ingénierie de plate-forme, sans reconnaître intentionnellement la discipline. La mise en place d’une équipe d’ingénierie de plate-forme dédiée vous permet de passer à l’étape suivante et de créer des systèmes internes hautement performants qui autonomisent les développeurs, tout en réduisant l’écart avec les opérations.