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.
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.
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().
Avantages :
Inconvénients :
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!