Heim > Backend-Entwicklung > Golang > Cache-Implementierung Golang

Cache-Implementierung Golang

WBOY
Freigeben: 2023-05-21 19:58:06
Original
555 Leute haben es durchsucht

Während der Entwicklung einer Website oder Anwendung müssen auf einer Seite möglicherweise unterschiedliche Daten und Ressourcen geladen werden, von denen einige häufig angefordert werden. In diesem Fall kann das Abfragen der Datenbank oder das erneute Abrufen von Ressourcen bei jeder Anfrage dazu führen, dass die Website oder Anwendung langsam reagiert. Um dieses Problem zu lösen, können wir Caching-Technologie verwenden. In diesem Artikel wird erläutert, wie Caching in Golang implementiert wird.

Caching in Golang

In Golang gibt es ein Paket namens „sync“, das eine Map-Parallelitätssichere Implementierung vom Typ „Map“ enthält. Wir können diese Karte verwenden, um Caching-Funktionalität zu implementieren.

Das Folgende sind die grundlegenden Schritte zum Implementieren von Caching in Golang:

  1. Definieren Sie eine globale Variable

Wir können eine globale Map-Variable definieren, um zwischengespeicherte Daten zu speichern. In dieser Map können wir Zeichenfolgen als „Schlüssel“ und jede Art von Variablen als „Werte“ verwenden.

var cache = struct {
    sync.RWMutex
    items map[string]interface{}
}{
    items: make(map[string]interface{}),
}
Nach dem Login kopieren

Im obigen Code wird die sync.RWMutex-Struktur verwendet, um sicherzustellen, dass der Cache-Vorgang threadsicher ist. Gleichzeitig wird mit der Make-Funktion eine leere Map erstellt.

  1. Daten zum Cache hinzufügen
func Set(key string, value interface{}, exp time.Duration) {
    cache.Lock()
    defer cache.Unlock()
    cache.items[key] = value
    if exp > 0 {
        time.AfterFunc(exp, func() {
            expire(key)
        })
    }
}
Nach dem Login kopieren

Im obigen Code verwenden wir die Methode „Lock“, um sicherzustellen, dass der Cache vor dem gleichzeitigen Zugriff mehrerer Goroutinen geschützt ist. Danach haben wir dem Cache ein Schlüssel-Wert-Paar hinzugefügt, wobei „key“ der zwischengespeicherte Schlüssel und „value“ der zwischengespeicherte Wert ist. Abschließend verwenden wir die Funktion „time.AfterFunc“, um die Cache-Zeit festzulegen. Wenn der Cache abläuft, wird automatisch die Methode „expire“ aufgerufen, um den Cache zu löschen.

  1. Daten aus dem Cache lesen
func Get(key string) (interface{}, bool) {
    cache.RLock()
    defer cache.RUnlock()
    val, ok := cache.items[key]
    return val, ok
}
Nach dem Login kopieren

Im obigen Code verwenden wir die Methode „RLock“, um den Cache zu sperren, um sicherzustellen, dass mehrere Goroutinen, die gleichzeitig darauf zugreifen, die zwischengespeicherten Daten frei lesen können. Anschließend rufen wir das entsprechende Schlüssel-Wert-Paar aus dem Cache ab. „val“ ist der abgerufene Wert und „ok“ gibt an, ob der Cache erfolgreich abgerufen wurde.

  1. Daten aus dem Cache entfernen
func Delete(key string) {
    cache.Lock()
    defer cache.Unlock()
    delete(cache.items, key)
}
Nach dem Login kopieren

Im obigen Code verwenden wir die „Lock“-Methode, um sicherzustellen, dass der Cache für mehrere Goroutinen, die gleichzeitig darauf zugreifen, sicher ist. Löschen Sie dann das entsprechende Schlüssel-Wert-Paar im Cache.

Beispielcode

Gemäß den obigen Schritten können wir eine einfache Cache-Implementierung schreiben. Der Code lautet wie folgt:

package main

import (
    "fmt"
    "sync"
    "time"
)

var cache = struct {
    sync.RWMutex
    items map[string]interface{}
}{
    items: make(map[string]interface{}),
}

func Set(key string, value interface{}, exp time.Duration) {
    cache.Lock()
    defer cache.Unlock()
    cache.items[key] = value
    if exp > 0 {
        time.AfterFunc(exp, func() {
            expire(key)
        })
    }
}

func Get(key string) (interface{}, bool) {
    cache.RLock()
    defer cache.RUnlock()
    val, ok := cache.items[key]
    return val, ok
}

func Delete(key string) {
    cache.Lock()
    defer cache.Unlock()
    delete(cache.items, key)
}

func expire(key string) {
    cache.Lock()
    defer cache.Unlock()
    delete(cache.items, key)
}

func main() {
    Set("key", "value", time.Second*10)

    val, ok := Get("key")
    if ok {
        fmt.Println(val)
    } else {
        fmt.Println("Value not found")
    }

    Delete("key")
}
Nach dem Login kopieren

Im obigen Beispiel verwenden wir die Set-Methode, um dem Cache ein Schlüssel-Wert-Paar hinzuzufügen und Stellen Sie die Cache-Zeit ein. Verwenden Sie dann die Get-Methode, um den gespeicherten Wert aus dem Cache zu lesen. Verwenden Sie abschließend die Methode „Delete“, um die gespeicherten Schlüssel-Wert-Paare zu löschen.

Fazit

In diesem Artikel haben wir die Methode zur Verwendung des Sync-Pakets zur Implementierung von Caching in Golang vorgestellt. Mit dieser Methode kann die Effizienz der Betriebsdaten verbessert und unnötige Datenbankabfragen reduziert werden. Ich hoffe, dieser Artikel kann Ihnen helfen, besser zu verstehen, wie Caching in Golang implementiert wird.

Das obige ist der detaillierte Inhalt vonCache-Implementierung Golang. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage