Avec le développement de la technologie Internet, les systèmes distribués sont de plus en plus utilisés, et l'appel de procédure à distance (RPC), en tant que méthode de communication importante dans les systèmes distribués, a également reçu de plus en plus d'attention et d'applications. Parmi les nombreux frameworks RPC, le langage Go, en tant que langage de programmation rapide et efficace, propose également une riche sélection de frameworks RPC. Cet article fera le point sur le framework RPC du langage Go, présentera les cinq choix populaires et donnera des exemples de code spécifiques pour aider les lecteurs à mieux comprendre et choisir le framework RPC adapté à leurs propres projets.
gRPC est un framework RPC open source hautes performances développé par Google, basé sur le protocole HTTP/2 et le protocole de sérialisation Protocol Buffers (ProtoBuf). gRPC fournit des fonctionnalités puissantes telles que la prise en charge multilingue, l'authentification, l'équilibrage de charge, etc. Voici un exemple simple de serveur et de client gRPC :
Exemple de code de serveur :
package main import ( "context" "log" "net" "google.golang.org/grpc" pb "path/to/your/proto/package" ) type server struct{} func (s *server) SayHello(ctx context.Context, in *pb.HelloRequest) (*pb.HelloResponse, error) { return &pb.HelloResponse{Message: "Hello " + in.Name}, nil } func main() { lis, err := net.Listen("tcp", ":50051") if err != nil { log.Fatalf("failed to listen: %v", err) } s := grpc.NewServer() pb.RegisterGreeterServer(s, &server{}) if err := s.Serve(lis); err != nil { log.Fatalf("failed to serve: %v", err) } }
Exemple de code client :
package main import ( "context" "log" "os" "time" "google.golang.org/grpc" pb "path/to/your/proto/package" ) func main() { conn, err := grpc.Dial("localhost:50051", grpc.WithInsecure()) if err != nil { log.Fatalf("did not connect: %v", err) } defer conn.Close() c := pb.NewGreeterClient(conn) name := "World" ctx, cancel := context.WithTimeout(context.Background(), time.Second) defer cancel() r, err := c.SayHello(ctx, &pb.HelloRequest{Name: name}) if err != nil { log.Fatalf("could not greet: %v", err) } log.Printf("Greeting: %s", r.Message) }
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!