3. September 2020
Der erfolgreiche Einsatz von Low-Code ist kein Selbstläufer
von Dr. Christian Straube, Adesso Schweiz AG
Low Code ist ein Paradigma in der modernen Softwareentwicklung. Es hat zum Ziel, die Entwicklung von Applikationen auch Personen ohne bzw. mit wenig Engineering-Hintergrund (sog. «Citizen Developers») zugänglich zu machen.
Damit sollen die meist knappen Entwickler-Ressourcen effektiver genutzt und die Arbeitszeit vorwiegend für die Umsetzung von Funktionalität anstatt für technische Grundlagen eingesetzt werden. Zudem wird die Zusammenarbeit zwischen Unternehmensbereichen für die Softwareentwicklung erheblich enger und Teams sollen sich gemeinsam noch mehr darauf konzentrieren können, Kunden- bzw. Anwendernutzen zu schaffen.
Der Ansatz: Softwareentwicklung-as-a-Service
Um diese Ziele zu erreichen, setzt Low-Code die in Abbildung 1 dargestellten vier Bausteine ein.
Die vier Bausteine und die entsprechenden Konzepte und Methoden gibt es – jeweils separat verwendet – schon seit geraumer Zeit, wie modellgetriebene Entwicklung oder CASE (Computer Aided Software Engineering). Low-Code-Plattformen kombinieren diese Bausteine nun aber auf neue Art und Weise, das heisst in einer homogenen und perfekt integrierten Umgebung, was neue Potentiale hervorbringt:
Aufwändige Initialisierungen für CASE-Werkzeuge und Modell-Übersetzer fallen weg, Systembrüche zwischen den Konzepten und Werkzeugen während der Entwicklung sind kaum bzw. nicht mehr spürbar, die Trennung zwischen Entwicklung und Betrieb wird erheblich reduziert, und die grafischen Modellierungswerkzeuge sind sofort einsetzbar und greifen nahtlos und für den Anwender transparent auf die anderen Komponenten zu. Das Ergebnis, eine aus den Modellen generierte Applikation, kann dann mit nur wenigen Klicks für die Produktion bereitgestellt werden.
Welche Probleme löst Low Code?
Der «Ready-to-Use»-Charakter geht über die Plattform selbst hinaus: einige Low-Code-Plattformen kommen mit einem ganzen Ökosystem für den Entwicklungs-Lifecycle, beispielsweise mit vorgefertigten Backend-Services, App Stores für Erweiterungen, oder der voll-integrierten Unterstützung für die Wiederverwendung von Artefakten innerhalb eines Unternehmens.
Das Low-Code-Paradigma möchte Probleme lösen, die sich aus den Kapazitätsengpässen in IT-Abteilungen und der gleichzeitigen Entwicklung von Geschwindigkeit zum zentralem Erfolgsfaktor ergeben. Richtig eingesetzt, bietet Low-Code gleich mehrere Vorteile: intensivere und effizientere Zusammenarbeit zwischen Nutzern, Business und IT, eine erheblich kürzere Time-to-Market, eine höhere Kosteneffektivität, reduzierte Anforderungen an die IT-Kapazität und eine höhere Qualität des Endergebnisses.
Abbildung 2 zeigt die Problemstellungen und welche Ziele das Low-Code-Paradigma dabei jeweils verfolgt.
Was heisst das konkret?
Das Low-Code-Paradigma bzw. Low-Code-Plattformen möchten die folgenden Ergebnisse liefern, um die Ziele zu den entsprechenden Problemstellungen zu erreichen:
- Effizientere Diskussion: Eine effizientere Diskdussion ist aus zwei Gründen möglich:
- Algorithmen werden visuell definiert und über (wichtige) Business-Logik kann so direkt und meist ohne weitere Aufbereitung gesprochen werden.
- Ergebnisse sind unmittelbar greifbar, wodurch die Diskussion nicht mit theoretischen, abstrakten Artefakten geführt werden muss, sondern es kann direkt über das Produkt gesprochen und Veränderungen gemeinsam vorgenommen werden.
- Früheres und schnelleres Feedback: Der Feedback-Prozess soll gleich auf drei Arten profitieren:
- Da sehr schnell eine erste lauffähige Version vorhanden ist – je nach Anwendung und Low-Code-Plattform bereits nach wenigen Tagen – kann frühzeitig Anwenderfeedback gesammelt werden.
- Je nach Plattform kann sogar direkt innerhalb der Anwendung Feedback gegeben werden, das dann in den Entwicklungsprozess zurückfliesst.
- Einige Low-Code-Plattformen stellen (anonymisierte) Informationen zum Anwendungs- und Nutzerverhalten bereit, d.h. beispielsweise welche Funktionalitäten häufig genutzt werden oder welche Teile der Anwendung verbessert werden könnten. Diese Informationen fliessen direkt zurück und können so schnell umgesetzt und den Anwendern wieder in Form von Verbesserungen bereitgestellt werden.
- Abbau von Hürden: Das Low-Code-Paradigma möchte IT und Business enger zusammenbringen und Fachbereiche als «Citizen Developers» zu einem Teil des Entwicklungsteams machen. Die Arbeit wird so besser verteilt und es gibt dank der gemeinsamen visuellen Definition viel weniger «Fachchinesisch“, das einzelne Gruppen ausschliesst.
- Schnellere Integration: Durch den Einsatz von Industriestandards und die Bereitstellung von System-Schnittstellen, die grafisch konfiguriert und anschliessend nahtlos in der Low-Code-Plattform genutzt werden können, ist die Integration häufig sehr schnell möglich. Dies ist besonders für zwei Punkte relevant: einerseits muss fast immer auf bestehende Datenbestände zugegriffen werden, andererseits ist für den Investitionsschutz eine möglichst lange Nutzung bestehender Applikationen wichtig.
- Besser eingesetzte Expertenzeit: Low-Code-Plattformen machen viele Architekturentscheide zur Applikation selbst obsolet, wodurch die zeitraubenden, immer wiederkehrenden Diskussionen zu Applikationsarchitektur oder Framework-Auswahl wegfallen. Dies macht nicht nur die Zusammenarbeit effektiver, sondern erhöht auch die Kosteneffektivität, da weniger Zeit für Grundsatzdiskussionen zu Framework-Auswahl oder Architekturentscheide notwendig ist. Stattdessen kann das gesamte Team das Kundenproblem besser durchdringen und sich so – über alle Bereiche hinweg – erheblich besser auf das Kerngeschäft fokussieren.
- Weniger Zertifizierungskosten: Nicht-funktionale Anforderungen zu Sicherheit und Qualität spielen bei nahezu jeder Applikation eine Rolle. Je nach Projekt kann aber eine zusätzliche Zertifizierung notwendig sein, beispielsweise zu Sicherheit oder regulatorischen Vorgaben. Diese meist kostenintensiven Zertifizierungen müssen nur einmal durchgeführt werden, da bei allen Folgeprojekten dank der Wiederverwendungsmöglichkeiten darauf zurückgegriffen werden kann.
- Weniger Aufwand: Der reduzierte Aufwand bezieht sich einerseits auf die Entwicklung, da durch die Wiederverwendung für die UI-Modellierung und die Code-Generierung erheblich weniger manuelle Arbeit notwendig ist. Andererseits werden für die Bereitstellung und den Betrieb umfangreiche Werkzeuge zu Deployment und Monitoring bereitgestellt, die Out-of-the-Box genutzt werden können.
- Geringere Fehlerquote: Die Fehlerquote kann aufgrund von drei Aspekten reduziert werden:
- Aus den grafisch erstellten Modellen werden die Applikationen generiert, und die eingesetzten Generierungsmechanismen haben bereits umfangreiche Tests durchlaufen.
- Konfigurationsfehler können grösstenteils mittels Konsistenzprüfungen während des One-Klick-Deployments ermittelt werden.
- Es können häufig Komponenten wiederverwendet werden, die bei einem früheren Einsatz getestet wurden.
Abbildung 3 stellt die Zusammenhänge zwischen den Zielen von Low-Code, den vier Low-Code-Bausteinen und den damit avisierten Ergebnissen dar.
Was vor dem Start beachtet werden sollte
Um die avisierten Ergebnisse zu erhalten und so alle Low-Code-Ziele wirklich zu realisieren (siehe Abbildung 3), gilt es nicht nur, die richtige Plattform auszuwählen. Vielmehr müssen eine Reihe von Vorbereitungen bei Vorgehensmodellen, bei Verantwortlichkeiten, bei der Qualitätssicherung und bei der Integration erfüllt werden, um von den Low-Code Versprechen nicht enttäuscht zu werden. Insbesondere bestehen folgende Risiken:
- Die neue Arbeitsweise erfordert ein Umdenken und der daraus resultierende Change wird unterschätzt.
- Eine hohe Abhängigkeit von der Low-Code Plattform führt zu Ablehnung.
- Unrealistische Erwartungen an die notwendigen Fähigkeiten für die Applikationsentwicklung führen zu Frust im gesamten Team.
- Unrealistische Erwartungen an die möglichen Ergebnisse und die entwickelten Applikationen gefährden Projektpläne und führen zu Enttäuschung.
- Bei der initialen Eignungsprüfung nicht berücksichtigte Kosten verfälschen den «Return on Investment» des Einsatzes von Low-Code.
- Die einfache Bedienung der Low-Code-Plattform führt dazu, dass erheblich mehr Anwendungen entwickelt werden als eigentlich notwendig, wodurch die IT-Kapazitäten nicht entlastet, sondern zusätzlich belastet werden.
Checkliste für eine ganzheitliche Betrachtung
Die Bandbreite der Risiken zeigt, dass die Vorbereitungen für und die Einbettung von Low-Code im Unternehmen ganzheitlich betrachtet werden muss. Abbildung 4 fasst die vier Bereiche «Technologie», «Prozesse», «Kultur» und «Organisation» sowie die jeweiligen Aspekte zusammen, die in Summe die Erfolgskriterien für den Einsatz von Low-Code im Unternehmen darstellen.
Je nach Unternehmenssituation werden die jeweiligen Kriterien mit unterschiedlichen Prioritäten behandelt. Dennoch sollten alle Bereiche adressiert werden, um die effektive und langfristig erfolgreiche Nutzung einer Low-Code-Plattform zu gewährleisten.
Applikationsentwicklung «demokratisieren» lohnt sich
Das Low-Code-Paradigma bietet eine lange Reihe von Vorteilen. Auch wenn es – wie alle anderen Werkzeuge auch – keine Allzweckwaffe ist, kann es doch einige Problemstellungen im Unternehmen beseitigen. Dabei helfen nicht nur die Philosophie, Applikationsentwicklung zu «demokratisieren», sondern auch der hohe Reifegrad vieler der verfügbaren Low-Code-Plattformen.
Obwohl die Liste an Herausforderungen und Risiken für Low-Code vergleichsweise lang ist, lässt sie sich mit methodischem Vorgehen in vergleichsweise kurzer Zeit bewältigen. Der Einsatz von Low-Code im Unternehmen sollte somit auf jeden Fall geprüft werden. Die dafür notwendigen Ressourcen zahlen sich bei einem erfolgreichen Einsatz von Low-Code schnell wieder aus.
Autor: Dr. Christian Straube ist Head Consulting Digital & Innovation bei der adesso Schweiz AG
Bilder: adesso Schweiz AG (Grafiken), Photo by Clayton Cardinalli on Unsplash (Teaser-Bild)
Disclaimer: adesso Schweiz ist ein swissICT Firmen-Mitglied. Firmen-Mitgliedern steht unser Blog offen für Themen-Inputs und Fachartikel. Die Beiträge müssen journalistischen Anforderungen genügen und dürfen nicht werblich sein. Sie möchten auch einen Beitrag publizieren? Für Fragen dazu benutzen Sie gerne
var JFL_91543917781365 = new JotformFeedback({
formId: ‚91543917781365‘,
base: ‚https://form.jotformeu.com/‘,
windowTitle: ‚IHRE ANFRAGE‘,
background: ‚#ac202f‘,
fontColor: ‚#FFFFFF‘,
type: ‚1‘,
height: 500,
width: 700,
openOnLoad: false
});
dieses Kontaktformular.