Varnish

Web-Beschleuniger für dynamische Webseiten

Varnish ist ein Cache für dynamische Webseiten mit viel Inhalt. Im Gegensatz zu anderen Reverse-Proxys, die häufig aus clientseitigen Proxys oder aus Servern entstanden, wurde Varnish von Grund auf als Reverse-Proxy konzipiert. Varnish wird von namhaften Internetseiten wie TAZ, Facebook, Twitter, SoundCloud[3], eBay, The New York Times[4], The Hindu, Vimeo, Die Zeit[5] und Wikipedia eingesetzt.[6]

Varnish

Basisdaten

Hauptentwickler Varnish Software
Entwickler Poul-Henning Kamp, Linpro, Varnish Software
Erscheinungsjahr 2005[1]
Aktuelle Version 7.6.1[2]
(8. November 2024)
Betriebssystem Unix
Programmier­sprache C
Kategorie Cache, HTTP-Accelerator
Lizenz BSD
deutschsprachig nein
varnish-cache.org

Entstehung

Bearbeiten

Das Projekt wurde initiiert durch den Online-Ableger der norwegischen Boulevardzeitung Verdens Gang. Architekt und Hauptentwickler ist der unabhängige dänische Softwareentwickler Poul-Henning Kamp. Management, Infrastruktur und zusätzliche Entwicklung wurden ursprünglich auch von der norwegischen Linux-Beratungsfirma Linpro zur Verfügung gestellt. Support, Management und Entwicklung von Varnish wurde später in eine eigenständige Firma, Varnish Software, ausgelagert.

Varnish ist freie Software, die unter der BSD-Lizenz steht. Kommerzieller Support wird unter anderem von Varnish Software angeboten.

Versionen

Bearbeiten
Version Veröffentlichungsjahr Anmerkungen/Referenzen
1.0 2006 [7]
2.0 2008 [8]
3.0 2011 [9][10]
4.0 2014 [11]
5.0 2016 [12]
6.0 2018 [13]
7.0 2021 [14]

Architektur

Bearbeiten

Varnish legt Daten im virtuellen Speicher ab und überlässt dem Betriebssystem die Entscheidung, was im Hauptspeicher verbleiben und was auf die Festplatte ausgelagert werden soll. Dies trägt dazu bei, Situationen zu vermeiden, in denen das Betriebssystem beginnt, Daten zu cachen, während sie durch die Applikation auf die Festplatte geschrieben werden.

Darüber hinaus ist Varnish stark thread-basiert. Jede Verbindung zu einem Client wird als separater Arbeitsthread behandelt. Ist das voreingestellte Limit von aktiven Arbeitsthreads erreicht, werden eingehende Verbindungen in eine Überlaufwarteschlange gestellt. Erst wenn das voreingestellte Limit dieser Warteschlange erreicht ist, werden eingehende Verbindungen abgelehnt.

Der hauptsächliche Konfigurationsmechanismus ist die Varnish Configuration Language (VCL), eine domänenspezifische Sprache, die dazu verwendet wird, bei kritischen Punkten in der Anfragebehandlung Hooks zu schreiben. Die meisten dieser Entscheidungen bleiben dabei dem VCL-Code überlassen, was Varnish deutlich stärker konfigurierbar und anpassbar macht als die meisten anderen Reverse-Proxys. Wenn ein VCL-Skript geladen wird, findet eine Übersetzung in C statt, es wird als Shared Object kompiliert und direkt in den Proxy gelinkt.

Eine Reihe von Laufzeiteinstellungen kontrollieren Parameter wie die maximale und minimale Anzahl der Arbeits-Threads und diverse Timeouts. Eine Schnittstelle auf Kommandozeilenebene erlaubt die Änderung dieser Parameter und das Kompilieren, Laden und Aktivieren neuer VCL-Skripte ohne einen Neustart des Proxys.

Um die Anzahl der Systemaufrufe auf ein Minimum zu reduzieren, werden Logdaten im Shared Memory abgelegt und die Aufgaben der Filterung, Formatierung und Speicherung auf Festplatte an eine getrennte Applikation übergeben.

Geschwindigkeit

Bearbeiten

Während Varnish so entwickelt wurde, dass Threads möglichst reibungslos nebeneinander ablaufen können, kann die Performance von Varnish nur so gut sein wie die Implementierung der pthreads auf dem Betriebssystem. Eine schlechte malloc-Implementierung kann außerdem unnötige Ressourcen beanspruchen und damit die Performance begrenzen.

Lastverteilung

Bearbeiten

Varnish unterstützt Lastverteilung sowohl im Round-Robin-Verfahren als auch zufällig gesteuert.[15]

Siehe auch

Bearbeiten
Bearbeiten

Einzelnachweise

Bearbeiten
  1. Introduction to Varnish. (abgerufen am 11. Januar 2020).
  2. Releases & Downloads. (abgerufen am 3. Januar 2025).
  3. What technologies is SoundCloud built on. Abgerufen am 26. Januar 2015 (englisch).
  4. Varnish Software – About. In: Facebook. Abgerufen am 14. Dezember 2014 (englisch, Seite der Varnish Software AS auf Facebook).
  5. Who relies on Varnish? In: varnish-software.com. Varnish Software AS, ehemals im Original (nicht mehr online verfügbar); abgerufen am 14. Dezember 2014 (englisch).@1@2Vorlage:Toter Link/www.varnish-software.com (Seite nicht mehr abrufbar. Suche in Webarchiven)  Info: Der Link wurde automatisch als defekt markiert. Bitte prüfe den Link gemäß Anleitung und entferne dann diesen Hinweis.
  6. Wikipedia:Server
  7. „Making Catalyst Sites Shine with Varnish“, Dec. 14, 2008
  8. „Varnish 2.0 released!“, Oct. 15 2008
  9. „Varnish Cache 3.0.0“ (Memento des Originals vom 1. Mai 2013 im Internet Archive)  Info: Der Archivlink wurde automatisch eingesetzt und noch nicht geprüft. Bitte prüfe Original- und Archivlink gemäß Anleitung und entferne dann diesen Hinweis.@1@2Vorlage:Webachiv/IABot/www.varnish-cache.org
  10. „Varnish Cache 3.0.0 released“, Jun. 16 2011
  11. „Varnish Cache 4.0.0“, Apr. 10 2014 (Memento des Originals vom 25. Mai 2014 im Internet Archive)  Info: Der Archivlink wurde automatisch eingesetzt und noch nicht geprüft. Bitte prüfe Original- und Archivlink gemäß Anleitung und entferne dann diesen Hinweis.@1@2Vorlage:Webachiv/IABot/www.varnish-cache.org
  12. varnishcache/varnish-cache. In: GitHub. Abgerufen am 8. November 2016.
  13. Varnish Cache 6.0.0 Release Notes. In: GitHub. Abgerufen am 17. März 2018.
  14. varnish-cache/changes.rst at master · varnishcache/varnish-cache. Abgerufen am 15. September 2021 (englisch).
  15. https://varnish-cache.org/wiki/BackendPolling