Upgrade to Pro — share decks privately, control downloads, hide ads and more …

Self-Contained Systems (German)

Self-Contained Systems (German)

Roman Stranghöner

March 11, 2015
Tweet

More Decks by Roman Stranghöner

Other Decks in Programming

Transcript

  1. Nach außen bildet ein SCS eine dezentrale Einheit, die nur

    über RESTful HTTP oder leichtgewichtiges Messaging mit anderen Systemen kommuniziert.
  2. Jedes SCS enthält eine eigene Benutzeroberfläche, eine für seine Fachlichkeit

    spezifische Geschäftslogik sowie separate Datenhaltung.
  3. Die Geschäftslogik eines SCS löst ausschließlich Probleme der zu Grunde

    liegenden Domäne. Diese Logik wird nur über eine klar definierte Schnittstelle mit anderen Systemen geteilt.
  4. Jedes SCS besitzt eine separate Datenhaltung, die unter Umständen eine

    für die Domäne erforderliche Redundanz ausweist.
  5. Auch wenn Redundanzen von Daten in Kauf genommen werden, beeinflusst

    dies nicht die Datenhoheit des führenden Systems.
  6. Dies ermöglicht polyglotte Persistenz, da unabhängig von anderen Systemen ein

    passendes DBMS für ein konkretes fachliches Problem eingesetzt werden kann. Neo4J Oracle CouchDB
  7. Innerhalb eines SCS können auch weitere flexible technische Entscheidungen getroffen

    werden. So etwa die Wahl der Programmiersprache, der eingesetzten Frameworks oder der Entwicklungswerkzeuge.
  8. Durch den klaren fachlichen Scope kann ein SCS von einem

    Team entwickelt, betrieben und gewartet werden. Team 1 Team 3 Team 2
  9. Soll die Navigation in beide Richtungen möglich sein, kann eine

    Rücksprung-Adresse mitgegeben werden. System 1 System 2
  10. Darüber hinaus können Links auch dazu genutzt werden, einzelne Seitenbereiche

    eines anderen SCS mit Hilfe von JavaScript dynamisch in die Benutzeroberfläche einzubetten. System 1 System 2
  11. Um die Kopplung zu anderen Systemen minimal zu halten sollte

    auf entfernte, synchrone Aufrufe innerhalb der Geschäftslogik verzichtet werden.
  12. Falls sich entfernte Aufrufe eines APIs nicht vermeiden lassen, sollten

    diese asynchron erfolgen, um Abhängigkeiten zu reduzieren und Fehlerkaskaden vorzubeugen.
  13. Um ein altes, monolithisches System in ein System of Systems

    zu überführen, empfiehlt sich in der Regel kein Big Bang Release, da dies insbesondere bei großen Systemen besonders fehleranfällig und riskant ist. Version 1
  14. Um ein altes, monolithisches System in ein System of Systems

    zu überführen, empfiehlt sich in der Regel kein Big Bang Release, da dies insbesondere bei großen Systemen besonders fehleranfällig und riskant ist. Version 2
  15. Statt dessen führen Anpassungen in häufigen, kleinen Schritten dazu, große

    und komplexe Systeme evolutionär zu modernisieren. Das Risiko eines Fehlschlags wird dabei erheblich minimiert.
  16. Statt dessen führen Anpassungen in häufigen, kleinen Schritten dazu, große

    und komplexe Systeme evolutionär zu modernisieren. Das Risiko eines Fehlschlags wird dabei erheblich minimiert.
  17. In der Realität besteht ein System of Systems in Teilen

    sowohl aus Individual-Software als auch aus Standardprodukten.
  18. Bei der Auswahl von Produkten ist darauf zu achten, dass

    die Software klar definierte Aufgaben erfüllt und sich über dieselben Mechanismen wie individuell entwickelte Self-Contained Systems integrieren lässt.
  19. Dies sorgt dafür, dass sich auch Standardprodukte nach Ablauf ihrer

    Nutzungszeit risikoarm durch ein nachfolgendes System ersetzen lassen.
  20. Dies sorgt dafür, dass sich auch Standardprodukte nach Ablauf ihrer

    Nutzungszeit risikoarm durch ein nachfolgendes System ersetzen lassen.
  21. Findet sich kein Produkt, dass sich nach den angestrebten Kriterien

    in das Gesamtsystem integrieren lässt, sollte eine Alternative gewählt werden, die sich zumindest um einheitliche Schnittstellen erweitern lässt.
  22. Krischerstr. 100 40789 Monheim am Rhein Germany +49 2173 3366-0

    Ohlauer Str. 43 10999 Berlin Germany +49 2173 3366-0 Ludwigstr. 180E 63067 Offenbach Germany +49 2173 3366-0 Kreuzstr. 16 80331 München Germany +49 2173 3366-0 Hermannstrasse 13 20095 Hamburg Germany +49 2173 3366-0 Gewerbestr. 11 CH-6330 Cham Switzerland +41 41 743 0116 innoQ Deutschland GmbH innoQ Schweiz GmbH www.innoq.com Weitere interessante Inhalte zum Thema Self-Contained Systems, Microservices, Monolithen, REST oder ROCA finden Sie auf https://www.innoq.com Bei Fragen oder Anregungen zögern Sie nicht uns zu kontaktieren [email protected]