Maison développement back-end Golang Comment résoudre les problèmes de mise en cache des requêtes et de mise à jour du cache des requêtes réseau simultanées en langage Go ?

Comment résoudre les problèmes de mise en cache des requêtes et de mise à jour du cache des requêtes réseau simultanées en langage Go ?

Oct 08, 2023 pm 01:21 PM
go语言 并发 解决 缓存更新 请求缓存

Comment résoudre les problèmes de mise en cache des requêtes et de mise à jour du cache des requêtes réseau simultanées en langage Go ?

Titre : Solution au problème de demande de mise en cache et de mise à jour du cache des requêtes réseau simultanées en langage Go

Introduction :
Dans le développement de programmes modernes, les requêtes réseau sont des opérations très courantes, et les requêtes simultanées visent à améliorer les performances du programme et la vitesse de réponse est clé. Cependant, dans les requêtes réseau simultanées, des problèmes tels que des requêtes répétées et des données incohérentes sont souvent rencontrés. Cet article explique comment résoudre ces problèmes dans le langage Go en utilisant la mise en cache des requêtes et la mise à jour du cache, et fournit des exemples de code spécifiques.

1. Implémentation de la mise en cache des requêtes

  1. Utilisation de sync.Map
    sync.Map dans le langage Go est un type de mappage thread-safe qui peut être utilisé comme structure de stockage pour la mise en cache des requêtes. Voici un exemple de code qui utilise sync.Map pour implémenter la mise en cache des requêtes :
package main

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

var cache sync.Map

func fetchData(url string) string {
    // 模拟网络请求
    time.Sleep(1 * time.Second)
    return fmt.Sprintf("Data from %s", url)
}

func getData(url string) string {
    // 先从缓存中获取数据
    if data, ok := cache.Load(url); ok {
        return data.(string)
    }

    // 如果缓存中不存在,则发送网络请求获取数据,并将其存入缓存
    data := fetchData(url)
    cache.Store(url, data)
    return data
}

func main() {
    urls := []string{"https://example.com", "https://google.com", "https://example.com"}

    for _, url := range urls {
        go func(url string) {
            fmt.Println(getData(url))
        }(url)
    }

    time.Sleep(3 * time.Second)
}
Copier après la connexion

La fonction getData dans le code ci-dessus utilise sync.Map pour implémenter la mise en cache des requêtes. Recherchez le cache avant chaque requête. S'il existe, renvoyez-le directement. Sinon, envoyez une requête réseau pour obtenir les données et stockez les données dans le cache. Dans l'exemple, trois URL identiques sont utilisées pour effectuer plusieurs requêtes simultanées afin de vérifier l'efficacité du cache.

  1. Utiliser GoCache
    GoCache est une bibliothèque de cache mémoire basée sur l'algorithme LRU, offrant des fonctions de mise en cache pratiques et efficaces. Voici un exemple de code qui utilise GoCache pour résoudre le problème de la mise en cache des requêtes simultanées :
package main

import (
    "fmt"
    "github.com/patrickmn/go-cache"
    "net/http"
    "time"
)

var c = cache.New(5*time.Minute, 10*time.Minute)

func fetchData(url string) string {
    // 发送网络请求获取数据
    resp, err := http.Get(url)
    if err != nil {
        return ""
    }
    defer resp.Body.Close()

    // 读取响应数据
    data, err := ioutil.ReadAll(resp.Body)
    if err != nil {
        return ""
    }

    return string(data)
}

func getData(url string) string {
    // 先从缓存中获取数据
    if data, found := c.Get(url); found {
        return data.(string)
    }

    // 如果缓存中不存在,则发送网络请求获取数据,并将其存入缓存
    data := fetchData(url)
    c.Set(url, data, cache.DefaultExpiration)
    return data
}

func main() {
    urls := []string{"https://example.com", "https://google.com", "https://example.com"}

    for _, url := range urls {
        go func(url string) {
            fmt.Println(getData(url))
        }(url)
    }

    time.Sleep(3 * time.Second)
}
Copier après la connexion

La fonction getData dans le code ci-dessus utilise GoCache pour implémenter le cache des requêtes simultanées. Recherchez le cache avant chaque requête. S'il existe, renvoyez-le directement. Sinon, envoyez une requête réseau pour obtenir les données et stockez les données dans le cache. Dans l'exemple, trois URL identiques sont utilisées pour effectuer plusieurs requêtes simultanées afin de vérifier l'efficacité du cache.

2. Problèmes et solutions aux mises à jour du cache
Dans les requêtes réseau simultanées, le cache doit souvent être mis à jour régulièrement pour maintenir les données à jour. Voici un exemple de code qui utilise des tâches planifiées et des verrous mutex pour résoudre le problème de mise à jour du cache :

package main

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

var cache sync.Map
var mutex sync.Mutex

func fetchData(url string) string {
    // 模拟网络请求
    time.Sleep(1 * time.Second)
    return fmt.Sprintf("Data from %s", url)
}

func getData(url string) string {
    // 先从缓存中获取数据
    if data, ok := cache.Load(url); ok {
        return data.(string)
    }

    // 如果缓存中不存在,则发送网络请求获取数据,并将其存入缓存
    mutex.Lock()
    defer mutex.Unlock()
    if data, ok := cache.Load(url); ok {
        return data.(string)
    }

    data := fetchData(url)
    cache.Store(url, data)
    return data
}

func updateCache() {
    for {
        time.Sleep(10 * time.Second)
        
        // 清空缓存
        cache.Range(func(key, value interface{}) bool {
            cache.Delete(key)
            return true
        })
    }
}

func main() {
    go updateCache()

    urls := []string{"https://example.com", "https://google.com", "https://example.com"}

    for _, url := range urls {
        go func(url string) {
            fmt.Println(getData(url))
        }(url)
    }

    time.Sleep(30 * time.Second) // 模拟程序运行一段时间
}
Copier après la connexion

La fonction getData dans le code ci-dessus utilise un verrou mutex lors de la demande pour garantir la cohérence des données du cache. Lorsque les données n'existent pas dans le cache, après l'acquisition du verrou, il est à nouveau déterminé si le cache existe déjà pour éviter des requêtes répétées. Dans le même temps, une tâche planifiée updateCache est ajoutée pour effacer les données du cache toutes les 10 secondes afin de simuler les mises à jour du cache. Dans l'exemple, trois URL identiques sont utilisées pour effectuer plusieurs requêtes simultanées afin de vérifier la validité et le mécanisme de mise à jour du cache.

Conclusion :
En utilisant la solution de mise en cache des requêtes et de mise à jour du cache, le problème des requêtes réseau simultanées peut être résolu efficacement en langage Go. Le choix d'un mécanisme de mise en cache approprié et d'une stratégie de mise à jour basée sur les besoins réels peut améliorer considérablement les performances du programme et la vitesse de réponse.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Quel est le problème avec le fil de file d'attente dans GO's Crawler Colly? Quel est le problème avec le fil de file d'attente dans GO's Crawler Colly? Apr 02, 2025 pm 02:09 PM

Problème de threading de file d'attente dans Go Crawler Colly explore le problème de l'utilisation de la bibliothèque Crawler Crawler dans le langage Go, les développeurs rencontrent souvent des problèmes avec les threads et les files d'attente de demande. � ...

Quelles bibliothèques sont utilisées pour les opérations du numéro de point flottantes en Go? Quelles bibliothèques sont utilisées pour les opérations du numéro de point flottantes en Go? Apr 02, 2025 pm 02:06 PM

La bibliothèque utilisée pour le fonctionnement du numéro de point flottante dans le langage go présente comment s'assurer que la précision est ...

Comment résoudre le problème de conversion de type user_id lors de l'utilisation du flux redis pour implémenter les files d'attente de messages dans le langage Go? Comment résoudre le problème de conversion de type user_id lors de l'utilisation du flux redis pour implémenter les files d'attente de messages dans le langage Go? Apr 02, 2025 pm 04:54 PM

Le problème de l'utilisation de Redessstream pour implémenter les files d'attente de messages dans le langage GO consiste à utiliser le langage GO et redis ...

Dans Go, pourquoi les chaînes d'impression avec println et string () ont-elles des effets différents? Dans Go, pourquoi les chaînes d'impression avec println et string () ont-elles des effets différents? Apr 02, 2025 pm 02:03 PM

La différence entre l'impression de chaîne dans le langage go: la différence dans l'effet de l'utilisation de fonctions println et string () est en Go ...

Que dois-je faire si les étiquettes de structure personnalisées à Goland ne sont pas affichées? Que dois-je faire si les étiquettes de structure personnalisées à Goland ne sont pas affichées? Apr 02, 2025 pm 05:09 PM

Que dois-je faire si les étiquettes de structure personnalisées à Goland ne sont pas affichées? Lorsque vous utilisez Goland pour le développement du langage GO, de nombreux développeurs rencontreront des balises de structure personnalisées ...

Quelles bibliothèques de GO sont développées par de grandes entreprises ou fournies par des projets open source bien connus? Quelles bibliothèques de GO sont développées par de grandes entreprises ou fournies par des projets open source bien connus? Apr 02, 2025 pm 04:12 PM

Quelles bibliothèques de GO sont développées par de grandes entreprises ou des projets open source bien connus? Lors de la programmation en Go, les développeurs rencontrent souvent des besoins communs, ...

Quelle est la différence entre la structure de définition des mots clés `var` et« type »dans le langage Go? Quelle est la différence entre la structure de définition des mots clés `var` et« type »dans le langage Go? Apr 02, 2025 pm 12:57 PM

Deux façons de définir les structures dans le langage GO: la différence entre les mots clés VAR et le type. Lorsque vous définissez des structures, GO Language voit souvent deux façons d'écrire différentes: d'abord ...

Pourquoi est-il nécessaire de passer des pointeurs lors de l'utilisation de bibliothèques Go et Viper? Pourquoi est-il nécessaire de passer des pointeurs lors de l'utilisation de bibliothèques Go et Viper? Apr 02, 2025 pm 04:00 PM

GO POINTER SYNTAXE ET ATTENDRE DES PROBLÈMES DANS LA BIBLIOTHÈQUE VIPER Lors de la programmation en langage Go, il est crucial de comprendre la syntaxe et l'utilisation des pointeurs, en particulier dans ...

See all articles