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

Inscription et découverte du service en langage Go

Jun 01, 2023 am 09:12 AM
go语言 服务注册 发现

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
}
Copier après la connexion

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)
}
Copier après la connexion

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

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Comment déverrouiller tout dans Myrise
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌

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

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

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

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

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

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