Was ist eine dreistufige Architektur?

Luftaufnahme von Tokio in der Abenddämmerung

Was ist eine dreistufige Architektur?

Eine dreischichtige Architektur ist eine etablierte Softwareanwendungsarchitektur, die Anwendungen in drei logische und physische Datenverarbeitungsschichten aufteilt: die Darstellungsschicht oder Benutzerschnittstelle; die Anwendungsschicht, wo Daten verarbeitet werden; und die Datenschicht, in der die mit der Anwendung verbundenen Daten gespeichert und verwaltet werden.

Der Hauptvorteil der dreischichtigen Architektur besteht darin, dass jede Schicht auf ihrer eigenen Infrastruktur ausgeführt wird, jede Schicht gleichzeitig von einem eigenen Entwicklungsteam entwickelt und bei Bedarf aktualisiert oder skaliert werden kann, ohne die anderen Schichten zu beeinträchtigen.

Jahrzehntelang war die dreischichtige Architektur die vorherrschende Architektur für Client-Server-Anwendungen. Heute sind die meisten dreischichtigen Anwendungen Ziele für eine Modernisierung unter Verwendung cloudnativer Technologien wie Container und Microservices sowie für eine Migration in die Cloud.

Verpassen Sie keinen technischen Durchbruch

Entdecken Sie mit dem monatlichen Future Forward Newsletter neue Forschungsergebnisse von IBM Experten in den Bereichen KI, Quantum, Hybrid Cloud und mehr. Weitere Informationen in der IBM Datenschutzerklärung.

Vielen Dank! Sie haben ein Abonnement abgeschlossen.

Ihr Abonnement wird auf Englisch geliefert. In jedem Newsletter finden Sie einen Abmeldelink. Hier können Sie Ihre Abonnements verwalten oder sich abmelden. Weitere Informationen finden Sie in unserer IBM Datenschutzerklärung.

Die drei Schichten im Detail

Darstellungsschicht

Die Darstellungsschicht ist die Benutzerschnittstelle und die Kommunikationsschicht der Anwendung, in der der Endbenutzer mit der Anwendung interagiert. Ihr Hauptzweck ist die Anzeige von Informationen für den Benutzer und die Erfassung von Informationen vom Benutzer. Diese Schicht der höchsten Ebene kann beispielsweise in einem Web-Browser, als Desktopanwendung oder als grafische Benutzerschnittstelle (GUI) ausgeführt werden. Webdarstellungsschichten werden in der Regel mit HTML, CSS und JavaScript entwickelt. Desktopanwendungen können je nach Plattform in einer Vielzahl von Sprachen geschrieben werden.

Anwendungsschicht

Die Anwendungsschicht, die auch als logische Schicht oder Mittelschicht bezeichnet wird, ist das Herz der Anwendung. In dieser Schicht werden Informationen verarbeitet, die in der Darstellungsschicht erfasst werden (manchmal gegenüber anderen Informationen in der Datenschicht), unter Verwendung von Geschäftslogik, einem bestimmten Satz von Business Rules. Die Anwendungsschicht kann auch Daten in der Datenschicht hinzufügen, löschen oder ändern.

Die Anwendungsschicht wird in der Regel mit Python, Java, Perl, PHP oder Ruby entwickelt und kommuniziert mit der Datenschicht über  API-Aufrufe.

Datenschicht

In der Datenschicht, die manchmal als Datenbankschicht, Datenzugriffsebene oder Back-End bezeichnet wird, werden die von der Anwendung verarbeiteten Informationen gespeichert und verwaltet. Dies kann ein relationales Datenbankverwaltungssystem wie PostgreSQL, MySQL, MariaDB, Oracle, Db2, Informix oder Microsoft SQL Server oder ein NoSQL-Datenbankserver wie Cassandra, CouchDB oder MongoDB sein.

In einer dreischichtigen Anwendung durchläuft die gesamte Kommunikation die Anwendungsschicht. Die Darstellungsschicht und die Datenschicht können nicht direkt miteinander kommunizieren.

Anwendungsentwicklung

Steigen Sie ein: Entwicklung von Enterprise-Anwendungen in der Cloud

In diesem Video erläutert Dr. Peter Haumer, wie die moderne Entwicklung von Unternehmensanwendungen in der Hybrid Cloud heute aussieht, indem er verschiedene Komponenten und Praktiken demonstriert, darunter IBM Z Open Editor, IBM Wazi und Zowe. 

Vorteile der dreischichtigen Architektur

Der Hauptvorteil der dreischichtigen Architektur ist die logische und physische Trennung der Funktionalität. Jede Schicht kann auf einem separaten Betriebssystem und einer separaten Serverplattform (z. B. Web-Server, Anwendungsserver, Datenbankserver) ausgeführt werden, die den funktionalen Anforderungen am ehesten entspricht. Und jede Schicht wird auf mindestens einer dedizierten Server-Hardware oder einem Virtual Server ausgeführt, sodass die Services jeder Schicht ohne Auswirkungen auf die anderen Schichten angepasst und optimiert werden können.

Weitere Vorteile (im Vergleich zu ein- oder zweistufigen Architektur):

  • Schnellere Entwicklung: Da jede Schicht gleichzeitig von verschiedenen Teams entwickelt werden kann, kann ein Unternehmen die Anwendung schneller auf den Markt bringen, und Programmierer können die neuesten und besten Sprachen und Tools für jede Schicht verwenden.

  • Verbesserte Skalierbarkeit: Jede Schicht kann nach Bedarf unabhängig von den anderen skaliert werden.
  • Verbesserte Zuverlässigkeit: Ein Ausfall in einer Schicht wirkt sich weniger wahrscheinlich auf die Verfügbarkeit oder Leistung der anderen Schichten aus.

  • Verbesserte Sicherheit: Da die Darstellungsschicht und die Datenschicht nicht direkt kommunizieren können, kann eine gut konzipierte Anwendungsschicht als eine Art interne Firewall fungieren, um SQL-Injections und andere zerstörerische Exploits zu verhindern.

Schichten vs. Ebenen

In Gesprächen über dreischichtige Architektur wird der Begriff Ebene häufig synonym – und fälschlicherweise – für Schicht verwendet, wie in „Darstellungsebene“ oder „Geschäftslogikebene“.

Sie sind jedoch nicht austauschbar. „Ebene“ bezieht sich auf einen funktionalen Bereich der Software, wohingegen sich „Schicht“ auf einen funktionalen Bereich der Software bezieht, die auf einer von den anderen Bereichen getrennten Infrastruktur ausgeführt wird. Die App „Kontakte“ auf Ihrem Telefon ist beispielsweise eine Anwendung mit drei Ebenen, jedoch eine einschichtige Anwendung, weil alle drei Ebenen auf Ihrem Telefon ausgeführt werden.

Der Unterschied ist wichtig, denn Ebenen bieten nicht die gleichen Vorteile wie Schichten.

Dreischichtige Anwendung in der Webentwicklung

In der Webentwicklung haben die Schichten unterschiedliche Namen, führen aber ähnliche Funktionen aus:

  • Der Webserver ist die Darstellungsschicht und stellt die Benutzerschnittstelle bereit. Dies ist in der Regel eine Webseite oder Website, wie z. B. eine E-Commerce-Site, wo der Benutzer Produkte zum Warenkorb hinzufügt, Zahlungsdetails hinzufügt oder ein Konto erstellt. Der Inhalt kann statisch oder dynamisch sein und wird normalerweise mit HTML, CSS und Javascript entwickelt.

  • Der Anwendungsserver entspricht der Mittelschicht, die die Geschäftslogik für die Verarbeitung von Benutzereingaben enthält. Um das E-Commerce-Beispiel fortzusetzen, ist dies die Schicht, die die Bestandsdatenbank abfragt, um die Produktverfügbarkeit zurückzugeben, oder Details zu einem Kundenprofil hinzufügt. Diese Schicht wird häufig mit Python, Ruby oder PHP entwickelt und führt ein Framework wie z. B. Django, Rails, Symphony oder ASP.NET aus.

  • Der Datenbankserver ist die Daten- oder Back-End-Schicht einer Webanwendung. Die Ausführung erfolgt durch eine Datenbankmanagementsoftware, wie z. B. MySQL, Oracle, DB2 oder PostgreSQL.

Andere mehrschichtige Architekturen

Während die dreischichtige Architektur einfach die am weitesten verbreitete mehrschichtige Anwendungsarchitektur ist, gibt es andere, denen Sie bei Ihrer Arbeit oder Forschung möglicherweise begegnen.

Zweischichtige Architektur

Die zweischichtige Architektur ist die ursprüngliche Client-Server-Architektur, die aus einer Darstellungsschicht und einer Datenschicht besteht. Die Geschäftslogik ist in der Darstellungsschicht, der Datenschicht oder beiden enthalten. In einer zweischichtigen Architektur hat die Darstellungsschicht – und damit der Endbenutzer – direkten Zugriff auf die Datenschicht, und die Geschäftslogik ist oft eingeschränkt. Eine einfache Kontaktmanagementanwendung, in der Benutzer Kontaktdaten eingeben und abrufen können, ist ein Beispiel für eine zweischichtige Anwendung.

N-schichtige Architektur

N-schichtige Architektur (auch mehrschichtige Architektur genannt) bezieht sich auf eine beliebige Anwendungsarchitektur mit mehr als einer Schicht. Aber Anwendungen mit mehr als drei Schichten sind selten, weil zusätzliche Schichten wenige Vorteile bieten und die Anwendung langsamer, schwieriger zu verwalten und teurer in der Ausführung werden kann. Daher sind n-schichtige Architektur und mehrschichtige Architektur in der Regel Synonyme für eine dreischichtige Architektur.

Weiterführende Lösungen
IBM Enterprise Application Service für Java

Ein vollständig verwalteter, mandantenfähiger Service für die Entwicklung und Bereitstellung von Java-Anwendungen.

Java-Apps erkunden
DevOps-Lösungen

Verwenden Sie DevOps-Software und -Tools, um cloudnative Anwendungen für mehrere Geräte und Umgebungen zu erstellen, bereitzustellen und zu verwalten.

DevOps-Lösungen erkunden
Services für die Entwicklung von Unternehmensanwendungen

Die Entwicklung von Cloud-Anwendungen bedeutet: einmal erstellen, schnell iterieren und überall bereitstellen.

Services für die Anwendungsentwicklung
Machen Sie den nächsten Schritt

IBM Cloud Application Development Consulting Services bieten fachkundige Beratung und innovative Lösungen zur Optimierung Ihrer Cloud-Strategie. Arbeiten Sie mit den Cloud- und Entwicklungsexperten von IBM zusammen, um Ihre Anwendungen zu modernisieren, skalieren und beschleunigen und so transformative Ergebnisse für Ihr Unternehmen zu erzielen.

Mehr zu Services zur Anwendungsentwicklung Erste kostenlose Schritte beim Erstellen auf IBM Cloud