Maison >développement back-end >Golang >Comment implémenter la limitation de courant des demandes de routage en langage Go

Comment implémenter la limitation de courant des demandes de routage en langage Go

PHPz
PHPzoriginal
2023-12-17 18:57:401144parcourir

Comment implémenter la limitation de courant des demandes de routage en langage Go

Comment implémenter la limitation actuelle des requêtes de routage en langage Go

Avec le développement des applications web et l'augmentation du nombre d'utilisateurs, le nombre de requêtes adressées au serveur va également augmenter. Afin de garantir la stabilité et les performances du serveur, nous devons limiter le flux de requêtes. La limitation actuelle peut contrôler efficacement le nombre de requêtes et éviter les pannes de serveur ou la dégradation des performances. Dans le langage Go, vous pouvez utiliser la bibliothèque gomodule pour implémenter la limitation du flux de requêtes de routage. Ce qui suit présentera comment utiliser la bibliothèque gomodule pour implémenter la limitation du flux de requêtes de routage et joindra les exemples de code correspondants.

  1. Présentation de la bibliothèque gomodule
    Tout d'abord, nous devons introduire la bibliothèque gomodule dans le programme Go. La bibliothèque peut être obtenue à l'aide de la commande go get, qui est la suivante :

    go get -u github.com/juju/ratelimit
  2. Implémentation du limiteur de taux de requêtes
    Ensuite, nous devons implémenter un limiteur de débit de requêtes. Le limiteur de requêtes est une structure de type minuterie utilisée pour limiter la fréquence des requêtes. Nous pouvons utiliser le package ratelimit dans la bibliothèque gomodule pour implémenter le limiteur de débit de requêtes. L'exemple de code est le suivant :

    package main
    
    import (
     "fmt"
     "time"
    
     "github.com/juju/ratelimit"
    )
    
    func main() {
     // 设置每秒钟可以处理的请求数
     limit := ratelimit.NewBucket(time.Second, 10)
    
     // 模拟处理请求
     for i := 0; i < 20; i++ {
         // 获取当前时间
         startTime := time.Now()
    
         // 尝试获取一个请求令牌
         limit.Wait(1)
    
         // 处理请求
         fmt.Printf("Processing request %d
    ", i)
    
         // 计算处理时间
         elapsedTime := time.Since(startTime)
         fmt.Printf("Processing time: %dms
    ", elapsedTime.Milliseconds())
     }
    }

Dans l'exemple de code ci-dessus, nous créons un limiteur de requêtes qui peut gérer 10 requêtes par seconde via la fonction ratelimit.NewBucket. Ensuite, nous simulons le traitement de 20 requêtes et implémentons la limitation du courant des requêtes via la méthode limit.Wait(1). Avant que chaque demande ne soit traitée, nous utilisons time.Now() pour obtenir l'heure actuelle, puis calculons le temps de traitement après le traitement de la demande.

  1. Utiliser le limiteur de requêtes dans le routage
    Dans les applications Web réelles, nous utilisons généralement le routage pour gérer les requêtes. Voici un exemple de code de routage utilisant un limiteur de requêtes :

    package main
    
    import (
     "fmt"
     "net/http"
     "time"
    
     "github.com/juju/ratelimit"
    )
    
    func rateLimitMiddleware(next http.HandlerFunc, limit *ratelimit.Bucket) http.HandlerFunc {
     return func(w http.ResponseWriter, r *http.Request) {
         startTime := time.Now()
    
         // 尝试获取一个请求令牌
         limit.Wait(1)
    
         // 计算处理时间
         elapsedTime := time.Since(startTime)
         fmt.Printf("Processing time: %dms
    ", elapsedTime.Milliseconds())
    
         // 调用下一个处理器
         next(w, r)
     }
    }
    
    func helloHandler(w http.ResponseWriter, r *http.Request) {
     fmt.Fprintln(w, "Hello, world!")
    }
    
    func main() {
     // 创建请求限流器
     limit := ratelimit.NewBucket(time.Second, 10)
    
     // 创建路由器
     mux := http.NewServeMux()
    
     // 添加路由处理函数,并使用请求限流器中间件
     mux.HandleFunc("/", rateLimitMiddleware(helloHandler, limit))
    
     // 启动HTTP服务器
     http.ListenAndServe(":8080", mux)
    }

Dans l'exemple de code ci-dessus, nous créons d'abord une limite de limiteur de requêtes. Ensuite, nous avons créé un routeur multiplexeur et ajouté le middleware limiteur de taux de requêtes rateLimitMiddleware à la fonction de traitement de route helloHandler. Avant de traiter chaque requête, le middleware attendra un jeton de requête pour implémenter la limitation du flux de requêtes. Enfin, nous démarrons le serveur HTTP à l'aide de la fonction http.ListenAndServe.

En utilisant la bibliothèque gomodule, nous pouvons facilement implémenter une limitation du flux des demandes de routage. De cette façon, nous pouvons contrôler efficacement le volume de requêtes du serveur et éviter les pannes du serveur ou la dégradation des performances. Dans le même temps, l'utilisation du limiteur de requêtes peut nous aider à mieux comprendre la charge du serveur et à optimiser les performances du système.

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:
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