APIOps ist eine Methodik, welche die Konzepte von GitOps und DevOps auf API-Bereitstellungen anwendet. Genau wie DevOps unterstützt APIOps Teammitglieder dabei, problemlos Änderungen vorzunehmen und sie iterativ und automatisiert bereitzustellen. Diese Architektur veranschaulicht, wie Sie den gesamten API-Lebenszyklus und die API-Qualität mithilfe von APIOps verbessern können.
Architektur
Laden Sie eine Visio-Datei dieser Architektur herunter.
Workflow
API-Operatoren führen die Extraktorpipeline aus, um das Git-Repository mit der API-Verwaltungsinstanz zu synchronisieren und das Git-Repository mit API-Verwaltungsobjekten im erforderlichen Format aufzufüllen.
Wenn eine API-Änderung in der API Management-Instanz erkannt wird, wird ein Pull Request (PR) erstellt, der von Operatoren überprüft werden kann. Operatoren führen die Änderungen im Git-Repository zusammen.
API-Entwickler klonen das Git-Repository, erstellen eine Verzweigung und erstellen API-Definitionen mithilfe der OpenAPI-Spezifikation oder tools ihrer Wahl.
Wenn ein Entwickler Änderungen an das Repository pusht, wird ein PR zur Überprüfung erstellt.
Der PR kann abhängig von der erforderlichen Steuerungsebene automatisch genehmigt oder überprüft werden.
Nachdem Änderungen genehmigt und zusammengeführt wurden, stellt die Veröffentlichungspipeline die neuesten Änderungen auf der API Management-Instanz bereit.
API-Operatoren erstellen und ändern API Management-Richtlinien, Diagnosen, Produkte und andere relevante Objekte und committen dann die Änderungen.
Die Änderungen werden überprüft und nach der Genehmigung zusammengeführt.
Nach dem Zusammenführen der Änderungen stellt die Veröffentlichungspipeline die Änderungen mithilfe des API-Definitionsprozesses bereit.
Komponenten
Azure API Management erstellt konsistente und moderne API-Gateways für Back-End-Dienste. Neben der Weiterleitung von API-Aufrufen an Back-Ends überprüft diese Plattform auch Anmeldeinformationen, erzwingt Nutzungskontingente und protokolliert Metadaten.
Azure DevOps ist ein Dienst für die umfassende und nahtlose Verwaltung Ihres End-to-End-Entwicklungslebenszyklus, einschließlich Planung und Projektmanagement, Codeverwaltung bis hin zum Build- und Releasevorgang.
Azure Pipelines ermöglicht eine kontinuierliche Integration und kontinuierliche Zustellung (CI/CD), um Ihren Code zu testen und zu erstellen und an jedes Ziel zu versenden.
Azure Repos ist ein Satz mit Tools für die Versionskontrolle, einschließlich Standard-Kit, mit denen Sie Ihren Code verwalten können.
Alternativen
Diese Lösung nutzt Azure Repos für die Git-Funktionalität und Azure Pipelines für die Pipelines. Sie können alle vergleichbaren Technologien verwenden.
Szenariodetails
APIOps verwendet Versionskontrolle zum Verwalten von APIs und erstellt einen Überwachungspfad zu Änderungen an APIs, Richtlinien und Vorgängen.
API-Entwickler, die eine APIOps-Methodik verwenden, überprüfen und überwachen APIs früher und häufiger und erkennen und beheben Abweichungen von API-Standards schneller, um die Spezifikationen und die API-Qualität zu verbessern. Je mehr APIs Sie mit einem APIOps-Ansatz erstellen und bereitstellen, desto größer ist die Konsistenz zwischen den APIs.
Diese APIOps-Architektur verwendet Azure API Management als API-Verwaltungsplattform. Azure DevOps organisiert die API-Verwaltung. Azure Repos stellt Git-Funktionen bereit, und Azure Pipelines erstellt die CI/CD-Pipeline.
Mögliche Anwendungsfälle
- Jede Organisation, die APIs entwickelt und verwaltet
- Streng regulierte Branchen: Versicherungen, Banken, Finanzen, Regierung
Überlegungen
Diese Überlegungen setzen die Säulen des Azure Well-Architected Framework um, das aus einer Reihe von Leitprinzipien besteht, die zur Verbesserung der Qualität einer Workload verwendet werden können. Weitere Informationen finden Sie unter Microsoft Azure Well-Architected Framework.
Sicherheit
Sicherheit bietet Schutz vor vorsätzlichen Angriffen und dem Missbrauch Ihrer wertvollen Daten und Systeme. Weitere Informationen finden Sie unter Übersicht über die Säule „Sicherheit“.
Diese Lösung bietet mehrere sicherheitsbezogene Vorteile. Einzelne Entwickler - und sogar Entwickler - greifen nicht direkt auf die API-Verwaltungsinstanz zu, um Änderungen oder Aktualisierungen vorzunehmen. Stattdessen pushen die Benutzer Änderungen in ein Git-Repository, das von den Extraktor- und Veröffentlichungspipelines gelesen und auf die API Management-Instanz angewendet wird. Dieser Ansatz folgt der bewährten Sicherheitspraxis der geringsten Berechtigung, da den Teams keine Schreibrechte für die API Management-Dienstinstanz erteilt werden. In Diagnose- oder Problembehandlungsszenarien können Sie erweiterte Berechtigungen für einen begrenzten Zeitraum von Fall zu Fall gewähren.
Um sicherzustellen, dass die API Management-Instanzen best Practices für die Sicherheit verwenden, können Sie diese Lösung erweitern, um best Practices für die API zu erzwingen, indem Sie Tools von Drittanbietern und Komponententests verwenden. Teams können per PR-Überprüfung frühzeitig Feedback geben, wenn die vorgeschlagenen Änderungen an einer API oder Richtlinie gegen Standards verstoßen.
Neben dem Einrichten von Repository-Berechtigungen sollten Sie die folgenden Sicherheitsmaßnahmen in Git-Repositories implementieren, die mit API Management-Instanzen synchronisiert werden:
- Pull Request (PR)-Überprüfung: Verwenden von Branches und Schützen der Branches, die den Zustand der API Management-Instanzen darstellen, vor dem direkten Pushen von Änderungen an sie. PRs müssen mindestens einen Prüfer haben, um das Vier-Augen-Prinzip umzusetzen.
- Unveränderlicher Verlauf: Lassen Sie neue Commits nur über vorhandene Änderungen hinaus zu. Unveränderlicher Verlauf ist für Überwachungszwecke besonders wichtig.
- Multi-Faktor-Authentifizierung: Erfordert von Ihren Benutzer, dass diese zweistufige Authentifizierung aktivieren.
- Signierte Commits: Nur signierte Commits zulassen, die anschließend nicht mehr geändert werden können.
Kostenoptimierung
Bei der Kostenoptimierung geht es darum, unnötige Ausgaben zu reduzieren und die Betriebseffizienz zu verbessern. Weitere Informationen finden Sie unter Übersicht über die Säule „Kostenoptimierung“.
Verwenden Sie den Azure-Preisrechner, um die voraussichtlichen Kosten zu ermitteln.
API Management bietet die folgenden Ebenen: Consumption, Developer, Basic, Standard und Premium.
GitHub bietet einen kostenlosen Dienst. Um jedoch erweiterte sicherheitsbezogene Funktionen wie Codebesitzer oder erforderliche Prüfer verwenden zu können, benötigen Sie den Team-Plan. Weitere Informationen finden Sie unter der Preisübersicht für GitHub.
Optimaler Betrieb
Die Säule „Optimaler Betrieb“ deckt die Betriebsprozesse ab, die für die Bereitstellung einer Anwendung und deren Ausführung in der Produktion sorgen. Weitere Informationen finden Sie unter Übersicht über die Säule „Optimaler Betrieb“.
APIOps kann DevOps-Produktivität für API-Entwicklung und -Bereitstellungen steigern. Eines der nützlichsten Features ist die Möglichkeit, Git-Vorgänge zu nutzen, um schnell ein Rollback von Änderungen mit unerwünschtem Verhalten vorzunehmen. Das Commit-Diagramm enthält alle Commits, sodass es bei der Analyse zur Nachbereitung hilfreich sein kann.
API-Operatoren verwalten häufig mehrere Umgebungen für denselben API-Satz. Es ist üblich, mehrere Phasen einer API auf verschiedenen API Management Instanzen oder in einer freigegebenen API Management-Instanz bereitzustellen. Das Git-Repository, das die einzige Quelle der Wahrheit ist, zeigt, welche Versionen von Anwendungen derzeit in einem Cluster bereitgestellt werden.
Wenn jemand einen PR im Git-Repository erstellt, weiß der API-Operator, dass er neuen Code zu überprüfen hat. Wenn ein Entwickler beispielsweise die OpenAPI-Spezifikation verwendet und die API-Implementierung erstellt, fügen sie diesen neuen Code zum Repository hinzu. Die Operatoren können den PR überprüfen und sicherstellen, dass die zur Überprüfung übermittelte API den best Practices und Standards entspricht.
Effiziente Leistung
Leistungseffizienz ist die Fähigkeit Ihrer Workload, auf effiziente Weise eine den Anforderungen der Benutzer entsprechende Skalierung auszuführen. Weitere Informationen finden Sie unter Übersicht über die Säule „Leistungseffizienz“.
APIOps bietet viele Vorteile, aber wenn API Management-Landschaften wachsen, steigt auch die Komplexität der Verwaltung. Diese Lösung hilft bei der Bewältigung von Herausforderungen wie:
- Beibehalten des Überblicks über alle Umgebungen und API Management-Instanzen.
- Nachverfolgen kritischer Änderungen an APIs und Richtlinien.
- Erstellen eines Überwachungspfads für alle bereitgestellten Änderungen.
Bereitstellen dieses Szenarios
Die Bereitstellung dieser Lösung beinhaltet die folgenden Schritte:
Entwickeln Sie die API im Portal, oder nehmen Sie Änderungen an der OpenAPI-Spezifikation mithilfe eines Tools Ihrer Wahl vor.
Wenn Sie Änderungen im Portal vornehmen, können Sie den Extraktor ausführen, um automatisch alle APIs und andere relevante Richtlinien, Vorgänge und Konfigurationen aus API Management zu extrahieren. Sie können diese Informationen mit dem Git-Repository synchronisieren.
Verwenden Sie optional die Azure DevOps CLI, um einen neue Pull Request zu erstellen.
Der Extraktor-Workflow umfasst die folgenden Schritte:
Ausführen einer Pipeline, die Änderungen im Portal in die API Management-Instanz herunterlädt.
-
Im vorliegenden Szenario hat die Pipeline, die Änderungen im Portal in die API Management-Instanz herunterlädt, die folgenden Phasen: Extraktor erstellen, Artefakte über das Portal erstellen und Vorlagenbranch erstellen.
Extraktor erstellen
In dieser Phase wird der Extraktor-Code erstellt.
Artefakte über das Portal erstellen
In dieser Phase wird der Extraktor ausgeführt und es werden Artefakte erstellt, die einer Git-Repositorystruktur ähneln, wie im folgenden Screenshot gezeigt:
Vorlagenbranch erstellen
Nachdem das Artefakt generiert wurde, wird in dieser Phase ein PR mit den extrahierten Änderungen erstellt, der vom Plattformteam geprüft werden kann.
Wenn Sie den Extraktor zum ersten Mal ausführen, wird alles aus dem Git-Repository gepullt. Der erstellte PR enthält alle APIs, Richtlinien, Artefakte und so weiter.
Spätere Extraktionen enthalten nur Änderungen, die vor der Extraktion im PR vorgenommen wurden. Manchmal werden Änderungen nur an der Spezifikation einer API vorgenommen. Dies ist im folgenden PR-Beispiel der Fall.
Ein Prüfer wechselt zu Pull Requests, um die aktualisierten Pull Requests anzuzeigen. Sie können auch automatische Genehmigungen konfigurieren, um diesen Schritt zu automatisieren.
Nachdem der PR genehmigt wurde, wird eine weitere Pipeline ausgelöst, die von API Management auf dem Portal veröffentlicht wird. Im vorliegenden Beispiel hat sie die folgenden Phasen: Buildersteller, Buildabschluss und APIM-Instanzen veröffentlichen.
- Die Phase Buildersteller übernimmt die Erstellung neuer APIs.
- In der Phase Buildabschluss werden alle Löschungen verarbeitet.
- In der Phase APIM-Instanzen veröffentlichen werden Änderungen an der API Management-Instanz veröffentlicht.
Wenn diese Pipeline erfolgreich ausgeführt wurde, werden die Änderungen in der API Management-Instanz veröffentlicht.
Beitragende
Dieser Artikel wird von Microsoft gepflegt. Er wurde ursprünglich von folgenden Mitwirkenden geschrieben:
Hauptautor:
- Rishabh Saha | Principal Solution Architect
Melden Sie sich bei LinkedIn an, um nicht öffentliche LinkedIn-Profile anzuzeigen.
Nächste Schritte
- Azure Pipelines
- APIOps für Azure API Management
- CI/CD für API Management mit Azure Resource Manager-Vorlagen
- GitOps-Übersicht
- Weave GitOps
- Tutorial: Bereitstellen von Konfigurationen mithilfe von GitOps in einem Kubernetes-Cluster mit Azure Arc-Unterstützung