Microservice-Architektur - Skalierung

Beim Skalieren wird eine Software in verschiedene Einheiten zerlegt. Die Skalierung definiert auch die Skalierbarkeit. Skalierbarkeit ist das Potenzial, erweiterte Funktionen der Anwendung zu implementieren. Es hilft, die Sicherheit, Haltbarkeit und Wartbarkeit der Anwendung zu verbessern. Wir haben drei Arten von Skalierungsverfahren, die in der Industrie angewendet werden. Im Folgenden werden die verschiedenen Skalierungsmethoden sowie die entsprechenden Beispiele aus der Praxis aufgeführt.

X-Achsen-Skalierung

Die X-Achsen-Skalierung wird auch als horizontale Skalierung bezeichnet. Bei diesem Verfahren wird die gesamte Anwendung in verschiedene horizontale Teile unterteilt. Normalerweise kann jede Webserveranwendung diese Art der Skalierung haben. Stellen Sie sich eine normale MVC-Architektur vor, die der horizontalen Skalierung folgt (siehe folgende Abbildung).

Als Beispiel können wir jede JSP-Servlet-Anwendung betrachten. In dieser Anwendung steuert der Controller jede Anforderung und generiert bei Bedarf eine Ansicht, indem er mit dem Modell kommuniziert. Normalerweise folgen monolithische Anwendungen dieser Skalierungsmethode. Die X-Achsen-Skalierung ist sehr einfach und weniger zeitaufwendig. Bei dieser Methode wird eine Software abhängig von ihrer unterschiedlichen Aufgabe, für die das Gerät verantwortlich ist, skaliert. Beispielsweise ist der Controller für die Steuerung der eingehenden und ausgehenden Anforderung verantwortlich, die Ansicht ist für die Darstellung der Geschäftsfunktionalität für die Benutzer im Browser verantwortlich, während das Modell für die Speicherung unserer Daten verantwortlich ist und als Datenbank fungiert.

Y-Achsen-Skalierung

Die Y-Achsen-Skalierung wird auch als vertikale Skalierung bezeichnet, die eine Skalierung auf Ressourcenebene umfasst. Jedes DBaaS- oder Hadoop-System kann als Y-Achsen-skaliert betrachtet werden. Bei dieser Art der Skalierung wird die Benutzeranforderung durch Implementieren einer Logik umgeleitet und eingeschränkt.

Betrachten wir Facebook als Beispiel. Facebook muss in jeder Sekunde 1,79 Millionen Nutzer bedienen. Daher liegt die Kontrolle des Datenverkehrs in der großen Verantwortung der Facebook-Netzwerktechniker. Um jede Gefahr zu vermeiden, folgen sie der Y-Achsen-Skalierung, bei der mehrere Server gleichzeitig mit derselben Anwendung ausgeführt werden. Um dieses enorme Verkehrsaufkommen zu kontrollieren, leitet Facebook den gesamten Verkehr von einer Region zu einem bestimmten Server um, wie im Bild dargestellt. Diese Übertragung des Datenverkehrs basierend auf der Region wird in der Architektursprache als Lastausgleich bezeichnet.

Diese Methode zur Aufteilung von Ressourcen in kleine unabhängige Geschäftsbereiche wird als Y-Achsen-Skalierung bezeichnet.

Z-Achsen-Skalierung

Die Skalierung der X- und Y-Achse ist viel einfacher zu verstehen. Eine Anwendung kann jedoch auch auf Unternehmensebene skaliert werden, was als Z-Achsen-Skalierung bezeichnet wird. Im Folgenden finden Sie ein Beispiel für die Skalierung einer Taxiservice-Anwendung in den verschiedenen Branchen von Geschäftsbereichen.

Vorteile der Skalierung

  • Cost - Durch eine ordnungsgemäße Skalierung einer Software werden die Wartungskosten gesenkt.

  • Performance - Aufgrund der losen Kopplung ist die Leistung einer richtig skalierten Software immer besser als die einer nicht skalierten Software.

  • Load distribution - Mit verschiedenen Technologien können wir unsere Serverlast problemlos aufrechterhalten.

  • Reuse - Die Skalierbarkeit einer Software erhöht auch die Benutzerfreundlichkeit der Software.