Abo
  • Services:

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. Fraunhofer-Institut für Arbeitswirtschaft und Organisation IAO, Stuttgart, Esslingen
  2. eco Verband der Internetwirtschaft e.V., Köln

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
Blu-ray-Angebote
  1. (u. a. 3 Blu-rays für 15€, 2 Neuheiten für 15€)
  2. (u. a. ES Blu-ray 10,83€, Die nackte Kanone Blu-ray-Box-Set 14,99€)

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
       


Command and Conquer (1995) - Golem retro_

Grünes Gold, Kane und - jedenfalls in Deutschland - Cyborgs statt Soldaten stehen im Mittelpunkt aller Nostalgie für Command & Conquer.

Command and Conquer (1995) - Golem retro_ Video aufrufen
Kaufberatung: Die richtige CPU und Grafikkarte
Kaufberatung
Die richtige CPU und Grafikkarte

Bei PC-Hardware gab es 2018 viele Neuerungen: AMD hat 32 CPU-Kerne etabliert, Intel verkauft immerhin acht Cores statt vier und Nvidias Turing-Grafikkarten folgten auf die zwei Jahre alten Pascal-Modelle. Wir beraten bei Komponenten und geben einen Ausblick auf die kommenden Monate.
Von Marc Sauter

  1. Fujian Jinhua USA verhängen Exportverbot gegen chinesischen DRAM-Fertiger
  2. Halbleiter China pumpt 47 Milliarden US-Dollar in eigene Chip-Industrie
  3. Dell Neue Optiplex-Systeme in drei Größen und mit Dual-GPUs

Mobilität: Überrollt von Autos
Mobilität
Überrollt von Autos

CES 2019 Die Consumer Electronic Show entwickelt sich immer stärker zu einer Mobilitätsmesse. Größere Fernseher und leichtere Laptops sind zwar noch ein Thema, doch die Stars in Las Vegas haben Räder.
Ein Bericht von Dirk Kunde

  1. Link Bar JBL bringt Soundbar mit eingebautem Android TV doch noch
  2. Streaming LG und Sony bringen Airplay 2 nur auf neue Smart-TVs
  3. Master Series ZG9 Sony stellt seinen ersten 8K-Fernseher vor

Hunt Showdown (Beta) im Test: Hmmm Hmmm Hmmm Hmmm
Hunt Showdown (Beta) im Test
Hmmm Hmmm Hmmm Hmmm

Tolle Optik, klasse Sound, dichte Atmosphäre: Hunt Showdown von Crytek macht solo oder im Duo schon im Early Access viel Spaß, wenn man sich auf das Spielprinzip einlässt. Wer laut ist, stirbt oft und schnell.
Ein Test von Marc Sauter

  1. Laufzeitumgebung Cryengine 5.5 unterstützt Raytracing-Schatten

    •  /