Abo
  • IT-Karriere:

Serverless Computing: Mehr Zeit für den Code

Weniger Verwaltungsaufwand und mehr Automatisierung: Viele Entwickler bauen auf fertige Komponenten aus der Cloud, um die eigenen Anwendungen aufzubauen. Beim Serverless Computing verschwinden die benötigten Server unter einer dicken Abstraktionsschicht, was mehr Zeit für den eigenen Code lässt.

Artikel von Valentin Höbel veröffentlicht am
In der Serverless-Cloud ist die Hardware-Konfiguration aus Sicht der Entwickler nicht mehr wichtig.
In der Serverless-Cloud ist die Hardware-Konfiguration aus Sicht der Entwickler nicht mehr wichtig. (Bild: Montage Martin Wolf/Golem.de)

Entwickler, die ihre Anwendungen in einer Cloud-Umgebung unterbringen möchten, können aus einer Vielzahl von Anbietern und Modi wählen. Wer die Möglichkeit hat, nutzt immer häufiger sogenanntes Serverless Computing, oft auch Serverless Infrastructure oder auch Function as a Service (FaaS) genannt. Hinter diesen verwirrenden Begriffen versteckt sich ein Cloud-Computing-Modell, welches die Abstraktion zwischen physikalischer Hardware und dem genutzten Angebot auf die Spitze treibt und dadurch sehr viele Probleme abnimmt.

Die eher klassisch anmutende Nutzungsvariante des Serverless Computing sieht vor, dass Entwickler ihre Anwendungen bei einem Provider hochladen und zur Verfügung gestellte Funktionen oder Module einbetten. Diese sorgen dafür, dass die Aufgaben mit der eigentlichen Workload an den Anbieter ausgelagert werden.

Weitaus fortgeschrittener läuft es ab, wenn die Anwendung komplett auf Basis der zur Verfügung gestellten Funktionen aufgebaut wird. Demnach steuert der Entwickler Code-Schnipsel in einer vom Provider unterstützten Programmiersprache bei, die auf vordefinierte Ereignisse auf eine bestimmte Art und Weise reagieren (Event-driven).

In allen Fällen sind die anbieterseitigen Funktionen in der Regel zustandslos, was theoretisch eine beliebige Skalierung der Drittkomponenten ermöglicht. Für die Nutzung dieser Funktionen ist kein direkter Zugriff auf die Server oder Hardware notwendig, man arbeitet also im übertragenen Sinne ohne Server, also serverless.

Serverless als größtmögliche Abstraktion

Stellenmarkt
  1. Stromnetz Hamburg GmbH, Hamburg
  2. Concardis GmbH, Eschborn

Die Grenze zwischen Serverless Computing und PaaS (Platform as a Service) ist dabei fließend: Während ersteres Modell typischerweise den Upload von Code vorsieht, der sich nahtlos in eine Art Cloud-Framework einbetten soll, geht man beim Plattformbetrieb davon aus, dass Entwickler vollständige Anwendungen hochladen. Der Anbieter stellt womöglich nach Baukastenprinzip Apps wie Datenbanken oder E-Mail-Server zur Verfügung, womit der Entwickler sich seinen Software-Stack in einer meist grafisch ansprechenden Umgebung zusammenklicken kann. Die eigentliche Funktionalität der Hauptanwendung aber liefert der Entwickler bitteschön selbst: Alle Anwendungen im Stack wollen orchestriert und vom Nutzer administriert sowie bei Bedarf skaliert werden. Entwickler benötigen hierfür sowohl anbieterspezifisches Knowhow als auch Wissen rund um die eingesetzten Tools. Genauso wie beim Serverless Computing bezahlt er meist in verbrauchter Rechenzeit oder in verbrauchten Ressourcen (vCPUs, vRAM, vDisk).

  • Mögliche Anwendung von FaaS laut Alibaba Cloud (Quelle: Alibaba Cloud)
  • Mögliche Anwendung von FaaS laut Alibaba Cloud (Quelle: Alibaba Cloud)
  • Der lange Weg von der Legacy-Anwendung hin zu Microservices und FaaS (Quelle: Swisscom)
  • Abgrenzung IaaS, CaaS, PaaS und FaaS (Quelle: Alibaba Cloud)
  • Logische Architektur von OpenWhisk (Quelle: Apache.org)
Abgrenzung IaaS, CaaS, PaaS und FaaS (Quelle: Alibaba Cloud)

Wer mutig ist und sich gerne mit der Administration von Systemen auseinandersetzt, rollt nicht nur Apps aus wie bei PaaS, sondern verwaltet gleich eine eigene Infrastruktur in der Cloud. Infrastructure as a Service (IaaS) stellt unter anderem gekapselte Teilinfrastrukturen, bestehend aus VMs, Storage und virtuellen Netzen, zur Verfügung. All diese Komponenten wollen aufgesetzt, konfiguriert und miteinander verzahnt werden. Wenn die eigene Anwendung besonders stark frequentiert wird, skaliert der Entwickler die Ressourcen nach oben und setzt die nächsten Systeme auf, die er dann erneut in die bestehende Infrastruktur einbettet. Das eigene Programm läuft auf den zahlreichen VMs, die in der Regel über Ressourcen-Pools (Anzahl vCPUs, vRAM und vDisk insgesamt) abgerechnet werden. Oft ist es dabei egal, ob die verfügbaren Ressourcen genutzt werden - man zahlt immer für den gesamten Pool (oder die aktuellen VMs). Die Verwaltung der IaaS geschieht meist über eine grafische Oberfläche, wobei der Entwickler nur selten um die CLI herumkommt, wenn etwa Komponenten konfiguriert werden müssen.

Als Entwickler wird man durch die Steuerungsoberfläche des Cloud-Anbieters weniger gefordert, man benötigt aber umfangreiches Wissen im Bereich Systemadministration und ist regelmäßig mit der Pflege der Infrastruktur beschäftigt. Sehr erfahrene Cloud-Administratoren nutzen meist Automatisierungswerkzeuge wie Saltstack oder Ansible, um die Betreuung der Infrastruktur etwas weniger zeitintensiv zu gestalten. Der Entwickler hingegen, der möglichst schnell seine Anwendung online bringen möchte, schreckt womöglich vor der Anschaffung des notwendigen Knowhows zurück und setzt deshalb auf die größtmögliche Abstraktion des Serverless Computing.

Der Pfad in die Serverless Cloud ist holprig 
  1. 1
  2. 2
  3. 3
  4. 4
  5. 5
  6. 6
  7.  


Anzeige
Hardware-Angebote
  1. 127,99€ (Bestpreis!)
  2. (reduzierte Überstände, Restposten & Co.)

flauschi123 12. Nov 2018

BPM Systeme koennen das seit Jahrzehnten. AWS Stepfunctions sind auch nur eine kleine...

logged_in 09. Nov 2018

Hast Du dich schon mal mit Skalierung auseinandergesetzt? Wo du um Kubernetes nicht umher...

ThomasSV 09. Nov 2018

Seit in irgendeiner (IMO Gartner-) Studie stand, dass man damit irrsinnig Geld spart...


Folgen Sie uns
       


iPad OS ausprobiert

Apple hat die erste öffentliche Betaversion vom neuen iPad OS veröffentlicht. Wir haben uns das für die iPads optimierte iOS 13 im Test genauer angeschaut.

iPad OS ausprobiert Video aufrufen
Energie: Wo die Wasserstoffqualität getestet wird
Energie
Wo die Wasserstoffqualität getestet wird

Damit eine Brennstoffzelle einwandfrei arbeitet, braucht sie sauberen Wasserstoff. Wie aber lassen sich Verunreinigungen bis auf ein milliardstel Teil erfassen? Am Testfeld Wasserstoff in Duisburg wird das erprobt - und andere Technik für die Wasserstoffwirtschaft.
Ein Bericht von Werner Pluta

  1. Autos Elektro, Brennstoffzelle oder Diesel?
  2. Energiespeicher Heiße Steine sind effizienter als Brennstoffzellen
  3. Klimaschutz Großbritannien probt für den Kohleausstieg

In eigener Sache: Neue Workshops zu agilem Arbeiten und Selbstmanagement
In eigener Sache
Neue Workshops zu agilem Arbeiten und Selbstmanagement

Wir haben in unserer Leserumfrage nach Wünschen für Weiterbildungsangebote gefragt. Hier ist das Ergebnis: Zwei neue Workshops widmen sich der Selbstorganisation und gängigen Fehlern beim agilen Arbeiten - natürlich extra für IT-Profis.

  1. In eigener Sache ITler und Board kommen zusammen
  2. In eigener Sache Herbsttermin für den Kubernetes-Workshop steht
  3. Golem Akademie Golem.de startet Angebote zur beruflichen Weiterbildung

Forschung: Mehr Elektronen sollen Photovoltaik effizienter machen
Forschung
Mehr Elektronen sollen Photovoltaik effizienter machen

Zwei dünne Schichten auf einer Silizium-Solarzelle könnten ihre Effizienz erhöhen. Grünes und blaues Licht kann darin gleich zwei Elektronen statt nur eines freisetzen.
Von Frank Wunderlich-Pfeiffer

  1. ISS Tierbeobachtungssystem Icarus startet
  2. Sun To Liquid Solaranlage erzeugt Kerosin aus Sonnenlicht, Wasser und CO2
  3. Shell Ocean Discovery X Prize X-Prize für unbemannte Systeme zur Meereskartierung vergeben

    •  /