Maison  >  Article  >  développement back-end  >  Inscription et découverte du service en langage Go

Inscription et découverte du service en langage Go

PHPz
PHPzoriginal
2023-06-01 09:12:181810parcourir

Avec le développement de l'architecture des microservices, l'enregistrement et la découverte des services deviennent de plus en plus importants. Pour le langage Go, en raison de sa grande efficacité et de ses excellentes performances de concurrence, il devient de plus en plus populaire comme langage de développement de microservices. Cet article expliquera comment s'inscrire et découvrir les services en langage Go.

  1. Qu'est-ce que l'enregistrement et la découverte du service ?

L'enregistrement et la découverte du service signifient que le fournisseur de services enregistre son service auprès du centre d'enregistrement des services et que le consommateur du service obtient la liste des services disponibles auprès du centre d'enregistrement et appelle le service correspondant. Le registre de services peut être un processus indépendant ou un cluster indépendant utilisé pour stocker les informations du fournisseur de services.

L'objectif principal de l'enregistrement et de la découverte de services est de simplifier l'appel et la gouvernance des services dans l'architecture des microservices.

  1. Enregistrement et découverte de services basés sur Consul

Consul est un outil de découverte et de configuration de services open source développé par HashiCorp et prend en charge plusieurs plates-formes et langues , y compris le langage Go. Ci-dessous, nous utiliserons Consul comme centre d'enregistrement des services pour présenter comment s'inscrire et découvrir les services dans la langue Go.

2.1 Installer Consul

Vous devez d'abord installer Consul, vous pouvez télécharger la version correspondante depuis son site officiel et l'installer.

2.2 Écrire le code du fournisseur de services

Nous devons ajouter du contenu au code du fournisseur de services pour l'enregistrement du service, en utilisant l'enregistrement et la découverte du service fournis par la bibliothèque go-micro Fonction .

package main

import (
    "log"
    "github.com/micro/go-micro"
    "github.com/micro/go-micro/server"
    "github.com/micro/go-plugins/registry/consul"
    "proto/hello"
)

func main() {
    service := micro.NewService(
        micro.Name("hello_service"),
        micro.Registry(consul.NewRegistry()),
    )
    service.Init()

    err := hello.RegisterHelloHandler(service.Server(), new(HelloHandler))
    if err != nil {
        log.Fatal(err)
    }

    if err := service.Run(); err != nil {
        log.Fatal(err)
    }
}

type HelloHandler struct{}

func (s *HelloHandler) SayHello(ctx context.Context, req *hello.Request, rsp *hello.Response) error {
    rsp.Msg = "Hello, " + req.Name
    return nil
}

Dans le code ci-dessus, nous utilisons la bibliothèque go-micro pour créer une instance de service et spécifier le composant de découverte de service qu'elle utilise en tant que Consul. Une fois le service enregistré, nous ajoutons notre service au serveur de l'instance de service via la fonction RegisterHelloHandler() pour gérer les demandes des clients.

2.3 Écrire le code du consommateur de service

Nous devons ajouter du contenu au code du consommateur de service pour la découverte de services, en utilisant la fonction de découverte de services fournie par la bibliothèque go-micro.

package main

import (
    "context"
    "fmt"
    "github.com/micro/go-micro"
    "github.com/micro/go-micro/client"
    "github.com/micro/go-plugins/registry/consul"
    "proto/hello"
)

func main() {
    service := micro.NewService(
        micro.Name("hello_client"),
        micro.Registry(consul.NewRegistry()),
    )
    service.Init()

    client := service.Client()

    helloService := hello.NewHelloService("hello_service", client)

    rsp, err := helloService.SayHello(context.Background(), &hello.Request{Name: "user"})
    if err != nil {
        fmt.Println(err)
        return
    }

    fmt.Println(rsp.Msg)
}

Dans le code ci-dessus, nous utilisons la bibliothèque go-micro pour créer une instance de service, et spécifions également le composant de découverte de service qu'elle utilise en tant que Consul. Nous utilisons le nom du service « hello_service » pour obtenir l'adresse du service lors de la création du client de service, puis envoyons une requête au fournisseur de services en appelant la méthode SayHello().

  1. Avantages et inconvénients de l'enregistrement et de la découverte de services

Avantages :

  1. Simplifiez l'invocation du service et processus de gouvernance, améliorant l’évolutivité et la maintenabilité du système.
  2. Réduit le codage en dur des dépendances d'adresses de service et le travail de maintenance manuelle des listes de services.
  3. Peut effectuer l'équilibrage de charge et le basculement des services, améliorant ainsi la disponibilité du système.

Inconvénients :

  1. Augmente la complexité du système et nécessite l'introduction de composants supplémentaires d'enregistrement et de découverte de services.
  2. Cela peut entraîner un retard supplémentaire sur le réseau, et des problèmes de bande passante et de performances du réseau doivent être pris en compte.
  3. Si le centre d'enregistrement des services tombe en panne, la disponibilité de l'ensemble du système sera affectée.
  4. Summary

Dans l'architecture des microservices, l'enregistrement et la découverte des services sont très importants. Cet article présente un exemple de code pour utiliser Consul comme centre d'enregistrement de services et analyse les avantages et les inconvénients de l'enregistrement et de la découverte de services. Dans les applications pratiques, nous devons sélectionner des solutions d'enregistrement et de découverte de services appropriées en fonction des besoins spécifiques de l'entreprise et de l'architecture du système, et procéder aux optimisations et ajustements appropriés.

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