Maison  >  Article  >  développement back-end  >  Comment utiliser la fonction serveur HTTP en langage Go pour implémenter la fonction de limitation actuelle du routage dynamique ?

Comment utiliser la fonction serveur HTTP en langage Go pour implémenter la fonction de limitation actuelle du routage dynamique ?

王林
王林original
2023-08-02 22:31:511276parcourir

Comment utiliser la fonction serveur HTTP dans le langage Go pour implémenter la fonction de limitation de flux du routage dynamique

Introduction :
Dans le processus de développement actuel, nous avons souvent besoin de contrôler le flux de l'interface API de l'application Web pour garantir que le système n'est pas inondé de requêtes malveillantes. Le langage Go fournit un ensemble complet de fonctions de serveur HTTP. Nous pouvons utiliser ces fonctions pour implémenter la fonction de limitation actuelle du routage dynamique.

Cet article expliquera comment utiliser la fonction de serveur HTTP dans le langage Go, combinée avec des algorithmes de limitation de courant couramment utilisés, pour implémenter la fonction de limitation de courant du routage dynamique.

1. Qu'est-ce que la limitation de courant de routage dynamique ?
La limitation actuelle du routage dynamique fait référence à la définition de différentes limites supérieures de taux de requêtes pour différents itinéraires (URI). Lorsque le nombre de requêtes pour un certain itinéraire dépasse la limite supérieure, le serveur rejette la demande pour cet itinéraire.

2. Utilisez Http.HandlerFunc pour implémenter le routage dynamique et la limitation de courant
Le package net/http en langage Go fournit la fonction HandleFunc pour acheminer les requêtes vers un traitement spécifique de manière fonctionnelle. Nous pouvons implémenter la fonction de limitation actuelle du routage dynamique dans la fonction HandleFunc. net/http包提供了HandleFunc函数,用于将请求路由到特定的处理函数上。我们可以在HandleFunc函数中实现动态路由的限流功能。

package main

import (
    "fmt"
    "net/http"
    "sync"
    "time"
)

// 路由统计信息
type RouteStats struct {
    Count      int       // 当前请求数
    LastAccess time.Time // 最近一次访问时间
}

// 路由限流器
type RouteLimiter struct {
    stats      map[string]*RouteStats // 路由统计信息
    maxReq     int                    // 最大请求数
    interval   time.Duration          // 统计时间间隔
    expiration time.Duration          // 统计信息过期时间
    lock       sync.Mutex             // 互斥锁
}

// 初始化路由限流器
func NewRouteLimiter(maxReq int, interval, expiration time.Duration) *RouteLimiter {
    return &RouteLimiter{
        stats:      make(map[string]*RouteStats),
        maxReq:     maxReq,
        interval:   interval,
        expiration: expiration,
    }
}

// 中间件,负责限流检查
func (rl *RouteLimiter) LimitHandler(next http.Handler) http.Handler {
    return http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
        // 获取路由
        route := r.URL.Path

        rl.lock.Lock()

        // 如果路由不存在,初始化统计信息
        if _, ok := rl.stats[route]; !ok {
            rl.stats[route] = &RouteStats{Count: 0}
        }

        stats := rl.stats[route]
        rl.lock.Unlock()

        // 检查请求数是否超过上限
        if stats.Count >= rl.maxReq {
            w.WriteHeader(http.StatusTooManyRequests)
            return
        }

        // 更新统计信息
        stats.Count++
        stats.LastAccess = time.Now()

        // 定时清理过期的统计信息
        go func() {
            time.Sleep(rl.expiration)
            rl.lock.Lock()
            defer rl.lock.Unlock()

            if time.Since(stats.LastAccess) >= rl.expiration {
                delete(rl.stats, route)
            }
        }()

        // 调用下一个处理程序
        next.ServeHTTP(w, r)
    })
}

// 处理路由
func handleRoute(w http.ResponseWriter, r *http.Request) {
    fmt.Fprint(w, "Hello, World!")
}

func main() {
    // 创建路由限流器
    limiter := NewRouteLimiter(10, time.Minute, time.Hour)

    // 设置路由处理函数
    http.HandleFunc("/", limiter.LimitHandler(http.HandlerFunc(handleRoute)))

    // 启动HTTP服务器
    http.ListenAndServe(":8080", nil)
}

上述代码首先定义了一个RouteStats结构体,用于存储路由的统计信息,包括请求数和最近访问时间。然后定义了一个RouteLimiter结构体,用于存储所有路由的统计信息,并提供限流功能的实现。

NewRouteLimiter函数用于初始化一个RouteLimiter对象,参数maxReq表示每个路由的最大请求数,interval表示统计时间间隔,expiration表示统计信息的过期时间。

LimitHandler方法是一个中间件,用于对每个请求进行限流检查。它首先获取请求的路由,然后检查该路由的请求数是否超过上限。如果超过上限,返回HTTP 429 Too Many Requests响应;否则更新统计信息,并定时清理过期的统计信息。

handleRoute函数为示例路由处理函数,这里简单返回一个 "Hello, World!" 字符串。

main函数中,我们创建了一个RouteLimiter对象,并设置了10个请求/分钟的限流策略。然后使用http.HandleFuncrrreee

Le code ci-dessus définit d'abord une structure RouteStats, qui est utilisée pour stocker les statistiques de routage, y compris le nombre de requêtes et l'heure d'accès la plus récente. Ensuite, une structure RouteLimiter est définie pour stocker les informations statistiques de toutes les routes et fournir l'implémentation de la fonction de limitation de courant.


La fonction NewRouteLimiter est utilisée pour initialiser un objet RouteLimiter. Le paramètre maxReq représente le nombre maximum de requêtes pour chaque route, et interval représente l'intervalle de temps statistique et expiration représente le délai d'expiration des informations statistiques.

La méthode LimitHandler est un middleware utilisé pour vérifier la limite actuelle de chaque requête. Il obtient d'abord l'itinéraire demandé, puis vérifie si le nombre de requêtes pour cet itinéraire dépasse la limite supérieure. Si la limite supérieure est dépassée, une réponse HTTP 429 Too Many Requests est renvoyée. Dans le cas contraire, les statistiques sont mises à jour et les statistiques expirées sont régulièrement effacées.

La fonction handleRoute est un exemple de fonction de traitement de routage, qui renvoie simplement une chaîne "Hello, World!".

🎜Dans la fonction main, nous avons créé un objet RouteLimiter et défini une politique de limitation actuelle de 10 requêtes/minute. Utilisez ensuite http.HandleFunc pour associer le middleware de routage et de limitation de courant, et enfin démarrez le serveur HTTP. 🎜🎜3. Conclusion🎜En utilisant la fonction serveur HTTP dans le langage Go, nous pouvons facilement implémenter la fonction de limitation actuelle du routage dynamique. En personnalisant le middleware et les limiteurs de débit, nous pouvons contrôler de manière flexible le flux de différents itinéraires pour garantir la stabilité et la sécurité du système. 🎜🎜Dans les applications réelles, nous pouvons personnaliser différentes stratégies de limitation de courant en fonction des besoins de l'entreprise, telles qu'un traitement personnalisé de limitation de courant basé sur l'identité de l'utilisateur, la méthode de demande, les paramètres de demande, etc. 🎜🎜(Fin)🎜

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