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:
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{}), }
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.
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) }) } }
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.
func Get(key string) (interface{}, bool) { cache.RLock() defer cache.RUnlock() val, ok := cache.items[key] return val, ok }
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.
func Delete(key string) { cache.Lock() defer cache.Unlock() delete(cache.items, key) }
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") }
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!