Godis implementiert einen Redis-kompatiblen Server vollständig in Go und dient als technische Referenz für nebenläufige Middleware. Der Quellcode adressiert Datenstrukturen, Persistenz und Cluster-Logik und zeigt, wie sich hohe Parallelität, Replikation und verteilte Transaktionen in einer kompakten Architektur umsetzen lassen.
Godis ist eine eigenständige Go-Implementierung eines Redis-Servers.
(Bild: Midjourney / KI-generiert)
Godis orientiert sich funktional an Redis und deckt zentrale Datentypen ab. Strings, Listen, Hashes, Sets, Sorted Sets, Bitmaps und GEO-Operationen stehen ebenso bereit wie TTL-Logik, Publish-Subscribe und Multi-Datenbank-Betrieb mit „SELECT“. Transaktionen arbeiten atomar und isoliert. Fehler innerhalb eines „MULTI“-Kontexts führen zum Rollback bereits ausgeführter Befehle, wodurch ein konsistenter Datenzustand erhalten bleibt.
RDB-Import und mehr
Die Persistenzschicht kombiniert RDB-Import und -Export mit AOF-Logging und AOF-Rewrite. Dadurch lassen sich Startzeiten und Datensicherheit ausbalancieren. Der Code trennt Protokollverarbeitung, Datenstrukturen und Speicherlogik strikt. Der TCP-Server nutzt eine ereignisgetriebene Implementierung auf Basis von gnet, um eine hohe Parallelität bei geringer Latenz zu erreichen. Interne Sperrmechanismen schützen Schlüssel granular und vermeiden globale Locks.
Ein zentrales Merkmal stellt der serverseitige Clusterbetrieb dar. Clients verbinden sich mit einem beliebigen Knoten und erhalten transparenten Zugriff auf den gesamten Datenbestand. Die Metadatenverwaltung basiert auf Raft. Der Cluster unterstützt dynamische Erweiterung, Rebalancing und Failover in experimenteller Ausprägung. Mehrschlüsselbefehle wie „MSET“, „MSETNX“, „DEL“, „RENAME“ und „RENAMENX“ arbeiten clusterweit atomar. Verteilte Transaktionen bleiben auf Slots begrenzt und nutzen eine Try-Commit-Catch-Logik zur Koordination.
Konfiguration durchführen
Die Konfiguration erfolgt über externe Dateien, deren Pfad per Umgebungsvariable gesetzt wird. Ohne gesetzte Variable greift Godis auf eine lokale redis.conf zurück. Beispielkonfigurationen für den Mehrknotenbetrieb liegen dem Projekt bei und zeigen die Initialisierung eines Clusters mit mehreren Instanzen. Der Server lauscht standardmäßig auf Port 6399 und akzeptiert Verbindungen über redis-cli oder kompatible Clients.
Benchmark-Ergebnisse auf moderner ARM-Hardware zeigen hohe Durchsatzraten bei Basisoperationen wie „GET“, „SET“, „INCR“ oder „PUSH“ und stabile Latenzen im niedrigen Millisekundenbereich. Umfangreiche „LRANGE“-Abfragen skalieren erwartungsgemäß mit der Elementanzahl. Die Messwerte verdeutlichen den Fokus auf Parallelität und Netzwerkpfad, weniger auf vollständige Funktionsparität mit Redis.
Der Quellcode eignet sich zur Analyse interner Abläufe. Die Struktur trennt Einstiegspunkt, Konfigurationsparser, Protokollverarbeitung, Datenstrukturen und Clusterlogik. Module für AOF, PubSub, Replikation und verteilte Transaktionen bleiben klar abgegrenzt. Godis positioniert sich damit nicht als produktiver Ersatz für Redis, sondern als nachvollziehbare Implementierung für Entwickler, die verteilte Key-Value-Systeme in Go verstehen und erweitern wollen.
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.