Abo
  • Services:
Anzeige
Sandstorm erreicht 55 GBit/s Datendurchsatz.
Sandstorm erreicht 55 GBit/s Datendurchsatz. (Bild: Universität Cambridge)

Sandstorm Spezial-Webserver ist 3,5-mal schneller als Nginx

Forscher der Universitäten Cambridge und London haben mit Sandstorm einen Webserver entwickelt, der auf die Auslieferung statischer Inhalte optimiert ist. Er ist in Tests dreimal so schnell wie Nginx und erzeugt dabei weniger CPU-Last, so dass er moderne Netzwerkhardware voll ausnutzen kann.

Anzeige

Spezialisierung für mehr Leistung: So lässt sich die Idee von Ilias Marinos und Robert Watson von der Universität Cambidge und Mark Handley vom University College London beschreiben. Aktuelle Netzwerk-Stacks seinen ein "Meisterwerk der Generalität", schrieben die drei, die mit ihrem Webserver Sandstorm zeigen, dass sich durch Spezialisierung die Leistung deutlich steigern lässt. Denn die herkömmlichen Netzwerk-Stacks basieren alle auf Code, der Anfang der 90er Jahre entstand.

Dieser wurde auf Basis des Netmap-Frameworks von FreeBSD entwickelt, das den Pufferspeicher der Netzwerk-Interfaces direkt in den Userspace mappt. Sandstorm ist ausschließlich dafür ausgelegt, statische Dateien auszuliefern. Und das soll Sandstorm deutlich schneller können als herkömmliche Webserver. Nach Ansicht der Forscher ist für solche Server in Systemlandschaften mit hunderten oder tausenden Servern, die spezielle Aufgaben übernehmen, ausreichend Platz. So könnten Server wie Sandstorm beispielsweise eingesetzt werden, um Bilder oder statische Inhalte aus einem Cache auszuliefern.

Es sind vor allen drei Dinge die Sandstorm schneller machen sollen als herkömmliche Webserver wie Nginx, die schon heute diverse Optimierungen nutzen, um statische Inhalte sehr schnell und mit geringer CPU-Last auszuliefern. Erstens haben die drei Forscher einen kompletten Zerocopy-Stack umgesetzt, so dass das Senden der Daten sehr effizient erfolgt. Das bezieht sich nicht nur auf Daten, die das Betriebssystem bereitstellt, beispielsweise Dateisystem-Blöcke, sondern umfasst auch HTTP-Header, die von der Applikation bereitgestellt werden.

Zweitens optimieren sie über traditionelle Grenzen hinweg, so dass beispielsweise Code auf Applikationsebene eine Vorabsegmentierung von Daten anfordern kann, um diese mehrfach auszuliefern. Zudem wird extensives Batching genutzt, um den Overhead von Systemaufrufen aus dem Userspace zu reduzieren.

Drittens ist die Implementierung synchron, ausgehend von empfangenen Paketen was das Caching verbessern und die Latenz beim Senden des ersten Antwort-Pakets minimieren soll. Dabei wird auf Queues und das Zwischenspeichern von Daten verzichtet.

Vorgefertigte Pakete

Letztendlich lädt Sandstorm eine statische Datei in den Speicher, generiert daraus alle Pakete, die gesendet werden müssen, um sie zu übertragen, einschließlich TCP, IP und Link-Layer-Headern. Wird die Datei angefragt, muss der Server nur noch TCP-Protokoll-Control-Blocks (TCB) anfordern, um den Status der Verbindung zu überwachen, die eigentlichen Pakete, die er senden muss, liegen aber schon fertig vor. Die Pakete werden dann direkt per Netmap an das Netzwerk-Interface gesendet.

3,5 Mal mehr Durchsatz als Nginx

Die Forscher haben ihre Implementierung gegen Nginx unter FreeBSD und Linux getestet, einmal auf alter Hardware (zwei Xeon X5355, Intels Netzwerkkarte 82598EB Dual Port 10GbE und 8 GByte RAM) mit Linux 3.6.7 und FreeBSD 9-Stable und einmal auf moderner Hardware (Xeon E5-2643 mit vier Kernen, 128 GByte RAM und drei Intel-Netzwerkkarte vom Typ 82599EB 10GbE) mit Linux 3.10.10 und FreeBSD 10-Current mit speziellen Patches von Netflix zur Optimierung von sendfile().

Auf alter Hardware erreicht Sandstorm bei zwei gleichzeitigen Verbindungen einen um rund 35 Prozent höheren Datendurchsatz. Mit steigender Zahl gleichzeitiger Verbindungen hat Sandstorm größere Vorteile. Allerdings ist es nicht möglich, die eine Netzwerkkarte mit kleinen Dateien auszulasten. Das gelingt erst bei Dateigrößen ab etwa 100 KByte.

Interessanter sind die Ergebnisse auf der modernen Hardware, die Data Direct I/O unterstützt und somit DMA-Zugriffe über PCIe von der Netzwerkkarte direkt auf den Last-Level Cache (LLC) des Prozessors zulässt. Sandstorm kann dadurch eine einzelne 10-Gigabit-Ethernet-Karte bei nur 13 Prozetn CPU-Last vollständig ausnutzen, skaliert linear bis zu sechs Netzwerkkarten und erreicht damit einen Datendurchsatz von 55 GBit/s bei 73 Prozent CPU-Last. Die konventionellen Stacks kommen den Forschern zufolge nicht über 16 GBit/s bei vier Netzwerkkarten.


eye home zur Startseite
am (golem.de) 13. Dez 2013

Das Forum basiert auf http://www.phorum.org/, allerdings haben wir daran mittlerweile...

boiii 12. Dez 2013

Das Vorschaubild ist leider immer nur als kleine Ansicht verfügbar. Es gibt sogar noch...

Gunah 12. Dez 2013

Das nginx langsamer ist als manche andere was Statische Dateien angeht ist doch...



Anzeige

Stellenmarkt
  1. über Kilmona PersonalManagement GmbH, Erlangen
  2. IKEA IT Germany GmbH, Hofheim-Diedenbergen
  3. DMG MORI AKTIENGESELLSCHAFT, Bielefeld
  4. censhare AG, München


Anzeige
Top-Angebote
  1. 14,99€ (ohne Prime bzw. unter 29€ Einkauf + 3€ Versand) - Bestpreis!
  2. 279€
  3. 99,90€ + 4,99€ Versand (Vergleichspreis 128€)

Folgen Sie uns
       


  1. Light L16

    Kamera mit 16 Kameramodulen soll DSLRs ersetzen

  2. Yara Birkeland

    Autonomes Containerschiff soll elektrisch fahren

  3. Airport Guide Robot

    LG lässt den Flughafenroboter los

  4. Biometrische Erkennung

    Delta lässt Passagiere mit Fingerabdruck boarden

  5. Niantic

    Keine Monster bei Pokémon-Go-Fest

  6. Essential Phone

    Rubins Smartphone soll "in den kommenden Wochen" erscheinen

  7. Counter-Strike Go

    Bei Abschuss Ransomware

  8. Hacking

    Microsoft beschlagnahmt Fancy-Bear-Infrastruktur

  9. Die Woche im Video

    Strittige Standards, entzweite Bitcoins, eine Riesenkonsole

  10. Bundesverkehrsministerium

    Dobrindt finanziert weitere Projekte zum autonomen Fahren



Haben wir etwas übersehen?

E-Mail an news@golem.de


Anzeige
Ikea Trådfri im Test: Drahtlos (und sicher) auf Schwedisch
Ikea Trådfri im Test
Drahtlos (und sicher) auf Schwedisch
  1. Die Woche im Video Kündigungen, Kernaussagen und KI-Fahrer
  2. Augmented Reality Ikea will mit iOS 11 Wohnungen virtuell einrichten
  3. Space10 Ikea-Forschungslab untersucht Umgang mit KI

Neuer A8 vorgestellt: Audis Staupilot steckt noch im Zulassungsstau
Neuer A8 vorgestellt
Audis Staupilot steckt noch im Zulassungsstau
  1. Autonomes Fahren Continental will beim Kartendienst Here einsteigen
  2. Verbrenner Porsche denkt über Dieselausstieg nach
  3. Autonomes Fahren Audi lässt Kunden selbstfahrenden A7 testen

Anker Powercore+ 26800 PD im Test: Die Powerbank für (fast) alles
Anker Powercore+ 26800 PD im Test
Die Powerbank für (fast) alles
  1. Toshiba Teures Thunderbolt-3-Dock mit VGA-Anschluss
  2. Asus Das Zenbook Flip S ist 10,9 mm flach
  3. Anker Powercore+ 26800 PD Akkupack liefert Strom per Power Delivery über USB Typ C

  1. Deswegen ist der E-Golf ja auch meist verkauft

    flasherle | 08:46

  2. Re: Cloud?

    TheArchive | 08:44

  3. Re: was raucht der Mann

    thinksimple | 08:43

  4. Re: Eine Beleidigung für echte Fotografen

    grumbazor | 08:42

  5. Re: Wieso?

    Bautz | 08:41


  1. 07:25

  2. 07:14

  3. 15:35

  4. 14:30

  5. 13:39

  6. 13:16

  7. 12:43

  8. 11:54


  1. Themen
  2. A
  3. B
  4. C
  5. D
  6. E
  7. F
  8. G
  9. H
  10. I
  11. J
  12. K
  13. L
  14. M
  15. N
  16. O
  17. P
  18. Q
  19. R
  20. S
  21. T
  22. U
  23. V
  24. W
  25. X
  26. Y
  27. Z
  28. #
 
    •  / 
    Zum Artikel