BigCache adressiert ein zentrales Problem speicherintensiver Go-Anwendungen mit hohen Zugriffsraten: Klassische Maps und pointerlastige Datenstrukturen belasten den Garbage Collector erheblich, sobald Millionen Einträge im Heap liegen. BigCache verfolgt einen anderen Ansatz und lagert Cache-Daten in Byte-Slices aus, die der GC nicht traversiert. Dadurch sinken Pausenzeiten auch bei extrem großen Datenmengen.
BigCache hält als In‑Memory‑Cache mit minimaler Garbage-Collection-Last die Performance von Anwendungen stabil.
(Bild: Midjourney / KI-generiert)
BigCache implementiert einen sharded Aufbau mit einer festen Anzahl von Segmenten, die parallel zugreifbar bleiben. Jeder Shard verwaltet seine Einträge eigenständig, was Lock-Contention reduziert und lineare Skalierung bei parallelen Zugriffen ermöglicht. Die interne Indexstruktur basiert auf „map[uint64]uint32“, wobei der Schlüssel als Hash vorliegt und der Wert auf einen Offset innerhalb eines Byte-Slices verweist. Da weder Schlüssel noch Werte Pointer enthalten, ignoriert der GC den eigentlichen Cache-Inhalt vollständig.
Einträge liegen sequentiell in großen Byte-Arrays. Diese Arrays können Größen im Gigabyte-Bereich erreichen, ohne dass sich die GC-Laufzeit proportional erhöht. Der GC sieht nur einen einzelnen Zeiger pro Slice. Serialization und Deserialization erfolgen außerhalb des Caches, da BigCache ausschließlich mit „[]byte“ arbeitet. Dieser Entwurf zwingt zur bewussten Kontrolle der Datenformate, reduziert jedoch Laufzeitkosten signifikant.
Lebensdauer von Cache-Einträgen steuern
Die Lebensdauer von Cache-Einträgen steuert BigCache über zwei Zeitparameter. LifeWindow definiert die maximale Gültigkeit eines Eintrags. Nach Ablauf dieser Zeit gilt der Eintrag als abgelaufen, verbleibt jedoch zunächst im Speicher. CleanWindow legt das Intervall fest, in dem ein Clean-up-Prozess abgelaufene Einträge physisch entfernt. Eine zu kurze Einstellung verursacht unnötige CPU-Last, da BigCache eine Sekundenauflösung nutzt. Eine zu lange Einstellung erhöht temporär den Speicherverbrauch, verändert jedoch nicht die logische Gültigkeit der Daten.
Für produktive Szenarien mit vorhersagbarer Last empfiehlt sich eine explizite Konfiguration. Die Anzahl der Shards beeinflusst die Parallelität direkt und muss eine Zweierpotenz darstellen. „MaxEntriesInWindow“ und „MaxEntrySize“ dienen ausschließlich der initialen Speicherreservierung und vermeiden spätere Reallokationen. „HardMaxCacheSize“ begrenzt den maximalen Speicherverbrauch in Megabyte. Sobald dieser Wert erreicht ist, überschreibt BigCache die ältesten Einträge shardweise. Dieses Verhalten erlaubt eine kontrollierte Speichergrenze ohne vollständige Eviktion.
BigCache bietet optionale Callback-Mechanismen für das Entfernen von Einträgen. „OnRemoveWithReason“ liefert eine Ursache für die Entfernung, etwa Ablauf der Lebensdauer, Platzmangel oder explizites Löschen. Diese Information erlaubt es, Nebenwirkungen außerhalb des Caches zu synchronisieren, ohne den internen Datenpfad zu blockieren. Wird kein Callback gesetzt, verbleibt die interne Datenstruktur vollständig ohne Entpacken der Einträge.
Hash-Kollisionen behandelt BigCache bewusst nicht. Trifft ein neuer Schlüssel auf einen bestehenden Hash, überschreibt der neue Eintrag den alten Wert. Diese Designentscheidung vermeidet zusätzliche Prüfungen im Hot Path und reduziert Latenzen. Anwendungen mit hohem Kollisionsrisiko müssen den Hashraum entsprechend wählen oder eigene Schutzmechanismen implementieren.
Aktuelles eBook
Storage-Software als Effizienzbooster
eBook „Storage-Software als Effizienzbooster“
(Bild: Storage-Insider)
Mit der geeigneten Storage-Software kann sich ein Unternehmen einen Effizienzbooster ins Haus holen oder in der Cloud abonnieren. Dieser Booster steigert nicht nur die Performance der geschäftskritischen Anwendungen, sondern optimiert auch die Kosten der bereits installierten Speichersysteme.
Die Themen im Überblick:
Herausforderungen eines modernen Speichersystems
Methoden und Technologien effizienter Speichersysteme
Effizienter Speicher mit Pure Storage, AWS, Cohesity und Dell
Es ist für uns eine Selbstverständlichkeit, dass wir verantwortungsvoll mit Ihren personenbezogenen Daten umgehen. Sofern wir personenbezogene Daten von Ihnen erheben, verarbeiten wir diese unter Beachtung der geltenden Datenschutzvorschriften. Detaillierte Informationen finden Sie in unserer Datenschutzerklärung.
Einwilligung in die Verwendung von Daten zu Werbezwecken
Ich bin damit einverstanden, dass die Vogel IT-Medien GmbH, Max-Josef-Metzger-Straße 21, 86157 Augsburg, einschließlich aller mit ihr im Sinne der §§ 15 ff. AktG verbundenen Unternehmen (im weiteren: Vogel Communications Group) meine E-Mail-Adresse für die Zusendung von Newslettern und Werbung nutzt. Auflistungen der jeweils zugehörigen Unternehmen können hier abgerufen werden.
Der Newsletterinhalt erstreckt sich dabei auf Produkte und Dienstleistungen aller zuvor genannten Unternehmen, darunter beispielsweise Fachzeitschriften und Fachbücher, Veranstaltungen und Messen sowie veranstaltungsbezogene Produkte und Dienstleistungen, Print- und Digital-Mediaangebote und Services wie weitere (redaktionelle) Newsletter, Gewinnspiele, Lead-Kampagnen, Marktforschung im Online- und Offline-Bereich, fachspezifische Webportale und E-Learning-Angebote. Wenn auch meine persönliche Telefonnummer erhoben wurde, darf diese für die Unterbreitung von Angeboten der vorgenannten Produkte und Dienstleistungen der vorgenannten Unternehmen und Marktforschung genutzt werden.
Meine Einwilligung umfasst zudem die Verarbeitung meiner E-Mail-Adresse und Telefonnummer für den Datenabgleich zu Marketingzwecken mit ausgewählten Werbepartnern wie z.B. LinkedIN, Google und Meta. Hierfür darf die Vogel Communications Group die genannten Daten gehasht an Werbepartner übermitteln, die diese Daten dann nutzen, um feststellen zu können, ob ich ebenfalls Mitglied auf den besagten Werbepartnerportalen bin. Die Vogel Communications Group nutzt diese Funktion zu Zwecken des Retargeting (Upselling, Crossselling und Kundenbindung), der Generierung von sog. Lookalike Audiences zur Neukundengewinnung und als Ausschlussgrundlage für laufende Werbekampagnen. Weitere Informationen kann ich dem Abschnitt „Datenabgleich zu Marketingzwecken“ in der Datenschutzerklärung entnehmen.
Falls ich im Internet auf Portalen der Vogel Communications Group einschließlich deren mit ihr im Sinne der §§ 15 ff. AktG verbundenen Unternehmen geschützte Inhalte abrufe, muss ich mich mit weiteren Daten für den Zugang zu diesen Inhalten registrieren. Im Gegenzug für diesen gebührenlosen Zugang zu redaktionellen Inhalten dürfen meine Daten im Sinne dieser Einwilligung für die hier genannten Zwecke verwendet werden. Dies gilt nicht für den Datenabgleich zu Marketingzwecken.
Recht auf Widerruf
Mir ist bewusst, dass ich diese Einwilligung jederzeit für die Zukunft widerrufen kann. Durch meinen Widerruf wird die Rechtmäßigkeit der aufgrund meiner Einwilligung bis zum Widerruf erfolgten Verarbeitung nicht berührt. Um meinen Widerruf zu erklären, kann ich als eine Möglichkeit das unter https://contact.vogel.de abrufbare Kontaktformular nutzen. Sofern ich einzelne von mir abonnierte Newsletter nicht mehr erhalten möchte, kann ich darüber hinaus auch den am Ende eines Newsletters eingebundenen Abmeldelink anklicken. Weitere Informationen zu meinem Widerrufsrecht und dessen Ausübung sowie zu den Folgen meines Widerrufs finde ich in der Datenschutzerklärung.