Maison >développement back-end >Golang >Comment implémenter la fonction de transfert de requêtes dans Golang

Comment implémenter la fonction de transfert de requêtes dans Golang

PHPz
PHPzoriginal
2023-04-05 10:29:541357parcourir

Le transfert de requêtes Golang fait référence à la méthode d'implémentation de la fonction de transfert de requêtes en langage Golang. Le transfert de demandes fait référence au transfert des demandes du client vers d'autres serveurs pour traitement, puis au renvoi des résultats du traitement au client. Le transfert de requêtes permet aux pages frontales d'accéder à des ressources sur différents serveurs, améliorant ainsi la disponibilité et l'évolutivité des applications Web. Dans cet article, nous présenterons comment implémenter la fonction de transfert de requêtes dans Golang.

  1. Scénarios d'application de transfert de requêtes

Dans le développement réel, nous avons souvent besoin de partager des données ou d'effectuer des tâches entre plusieurs serveurs et plusieurs applications. Le transfert de demandes peut distribuer les demandes des clients vers plusieurs serveurs pour traitement, améliorant ainsi l'utilisation des ressources et la vitesse de réponse. Le transfert de demandes est également un outil important pour créer des applications distribuées. Que ce soit sous la forme d'équilibrage de charge ou de serveurs proxy, les demandes peuvent être distribuées via le transfert de demandes.

  1. Méthodes pour implémenter le transfert de requêtes

2.1 Utilisation du proxy HTTP

Dans Golang, vous pouvez utiliser la structure ReverseProxy dans le package net/http pour implémenter le proxy HTTP afin de réaliser le transfert de requête. La structure ReverseProxy peut transmettre la demande reçue vers d'autres URL pour traitement et renvoyer le résultat au client après traitement. Voici un exemple de code utilisant ReverseProxy :

   package main

   import (
       "net/http"
       "net/http/httputil"
       "net/url"
   )

   func main() {
       proxy := httputil.NewSingleHostReverseProxy(&url.URL{
           Scheme: "http",
           Host:   "localhost:8080",
       })
       http.ListenAndServe(":80", proxy)
   }

Dans cet exemple de code, nous créons d'abord un proxy d'objet proxy et définissons l'adresse de la requête sur http://localhost:8080. Ensuite, nous lions l'objet proxy au serveur HTTP en appelant la fonction http.ListenAndServe, écoutons sur le port 80 et attendons les demandes des clients. Lorsqu'une demande client est reçue, l'objet proxy transmettra la demande à l'adresse du backend pour traitement et renverra enfin le résultat du traitement au client.

2.2 Utiliser l'interrogation pour implémenter l'équilibrage de charge

Une autre méthode courante de mise en œuvre du transfert de requêtes est le transfert de requêtes basé sur l'équilibrage de charge. L'équilibrage de charge fait référence à la distribution des requêtes des clients sur plusieurs serveurs afin que la charge du serveur soit aussi uniforme que possible et améliore la disponibilité et l'évolutivité du système. Dans Golang, un algorithme d'interrogation peut être utilisé pour équilibrer la charge et répartir uniformément les demandes des clients sur plusieurs serveurs.

Ce qui suit est un exemple de code qui utilise l'interrogation pour réaliser l'équilibrage de charge :

   package main

   import (
       "fmt"
       "io/ioutil"
       "log"
       "math/rand"
       "net/http"
       "net/url"
       "time"
   )

   // 定义所有可用的服务器列表
   var proxyList = []string{
       "http://localhost:8080",
       "http://localhost:8081",
       "http://localhost:8082",
   }

   func main() {
       proxy := &Proxy{
           urls:      make([]*url.URL, 0),
           current:   0,
           transport: &http.Transport{},
       }
       for _, p := range proxyList {
           u, _ := url.Parse(p)
           proxy.urls = append(proxy.urls, u)
       }
       // 监听80端口
       if err := http.ListenAndServe(":80", proxy); err != nil {
           panic(err)
       }
   }

   type Proxy struct {
       urls      []*url.URL
       current   int
       transport *http.Transport
   }

   func (p *Proxy) ServeHTTP(w http.ResponseWriter, r *http.Request) {
       // 随机获取一台服务器
       u := p.urls[p.current]
       p.current = (p.current + 1) % len(p.urls)

       // 设置协议和主机
       r.Header.Set("X-Forwarded-Host", r.Header.Get("Host"))
       r.Header.Set("X-Forwarded-Proto", "http")
       r.URL.Scheme = u.Scheme
       r.URL.Host = u.Host

       // 发送请求
       res, err := p.transport.RoundTrip(r)
       if err != nil {
           log.Printf("%s", err)
           w.WriteHeader(http.StatusInternalServerError)
           return
       }
       defer res.Body.Close()

       // 将结果返回给客户端
       for k, v := range res.Header {
           w.Header().Set(k, v[0])
       }
       w.WriteHeader(res.StatusCode)
       body, err := ioutil.ReadAll(res.Body)
       if err != nil {
           log.Printf("%s", err)
           w.WriteHeader(http.StatusInternalServerError)
           return
       }
       fmt.Fprintf(w, "%s", body)
   }

Dans cet exemple de code, nous définissons d'abord un proxy d'objet proxy, qui contient une liste de toutes les adresses de serveur disponibles. Ensuite, nous lions l'objet proxy au serveur HTTP en appelant la fonction http.ListenAndServe, écoutons sur le port 80 et attendons les demandes des clients. Lorsqu'une demande client est reçue, l'objet proxy sélectionne de manière aléatoire un serveur à traiter et envoie la demande à ce serveur. Une fois le traitement terminé, l'objet proxy renvoie les résultats au client.

  1. Résumé

Dans cet article, nous avons présenté deux méthodes pour implémenter la fonction de transfert de requêtes dans le langage Golang : en utilisant le proxy HTTP et le transfert de requêtes basé sur l'équilibrage de charge. Le proxy HTTP est une méthode courante de mise en œuvre du transfert de requêtes qui peut transmettre les requêtes à d'autres serveurs pour traitement, améliorant ainsi l'utilisation des ressources et la vitesse de réponse. L'équilibrage de charge est une méthode pratique et pratique de transfert de demandes. Il peut distribuer les demandes des clients sur plusieurs serveurs pour rendre la charge du serveur aussi uniforme que possible et améliorer la disponibilité et l'évolutivité du système. Qu'il s'agisse d'un proxy HTTP ou d'un équilibrage de charge, la fonction de transfert de requêtes peut être implémentée pour améliorer la disponibilité et l'évolutivité des applications Web.

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