• IT-Karriere:
  • 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. operational services GmbH & Co. KG, Wolfsburg, Zuffenhausen
  2. DMK E-BUSINESS GmbH, Berlin-Potsdam, Chemnitz

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.

Bitte aktivieren Sie Javascript.
Oder nutzen Sie das Golem-pur-Angebot
und lesen Golem.de
  • ohne Werbung
  • mit ausgeschaltetem Javascript
  • mit RSS-Volltext-Feed
Der Pfad in die Serverless Cloud ist holprig 
  1. 1
  2. 2
  3. 3
  4. 4
  5. 5
  6. 6
  7.  


Anzeige
Top-Angebote
  1. 179€ (Bestpreis)
  2. (u. a. Rocketman für 8,99€, Ready Player One für 8,79€, Atomic Blondie für 9,49€)
  3. (u. a. EA Promo (u. a. Unravel für 8,99€, Anthem für 8,99€), Tiny and Big: Grandpa's...
  4. 709€ (Bestpreis)

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
       


Surface Duo - Fazit

Das Surface Duo ist Microsofts erstes Smartphone seit Jahren - und ein ungewöhnliches dazu. Allerdings ist das Gerät in Deutschland viel zu teuer.

Surface Duo - Fazit Video aufrufen
Programm für IT-Jobeinstieg: Hoffen auf den Klebeeffekt
Programm für IT-Jobeinstieg
Hoffen auf den Klebeeffekt

Aktuell ist der Jobeinstieg für junge Ingenieure und Informatiker schwer. Um ihnen zu helfen, hat das Land Baden-Württemberg eine interessante Idee: Es macht sich selbst zur Zeitarbeitsfirma.
Ein Bericht von Peter Ilg

  1. Arbeitszeit Das Sechs-Stunden-Experiment bei Sipgate
  2. Neuorientierung im IT-Job Endlich mal machen!
  3. IT-Unternehmen Die richtige Software für ein Projekt finden

Weclapp-CTO Ertan Özdil: Wir dürfen nicht in Schönheit und Perfektion untergehen!
Weclapp-CTO Ertan Özdil
"Wir dürfen nicht in Schönheit und Perfektion untergehen!"

Der CTO von Weclapp träumt von smarter Software, die menschliches Eingreifen in der nächsten ERP-Generation reduziert. Deutschen Perfektionismus hält Ertan Özdil aber für gefährlich.
Ein Interview von Maja Hoock


    Fiat 500 als E-Auto im Test: Kleinstwagen mit großem Potenzial
    Fiat 500 als E-Auto im Test
    Kleinstwagen mit großem Potenzial

    Fiat hat einen neuen 500er entwickelt. Der Kleine fährt elektrisch - und zwar richtig gut.
    Ein Test von Peter Ilg

    1. Vierradlenkung Elektrischer GMC Hummer SUV fährt im Krabbengang seitwärts
    2. MG Cyberster MG B Roadster mit Lasergürtel und Union Jack
    3. Elektroauto E-Auto-Prämie übersteigt in 2021 schon Vorjahressumme

      •  /