Dengan perkembangan teknologi Internet, sistem yang diedarkan semakin digunakan secara meluas, dan Panggilan Prosedur Jauh (RPC), sebagai kaedah komunikasi penting dalam sistem teragih, juga telah mendapat perhatian dan aplikasi yang lebih banyak. Di antara banyak rangka kerja RPC, bahasa Go, sebagai bahasa pengaturcaraan yang pantas dan cekap, juga mempunyai banyak pilihan rangka kerja RPC. Artikel ini akan mengambil kira rangka kerja RPC bahasa Go, memperkenalkan lima pilihan popular dan memberikan contoh kod khusus untuk membantu pembaca lebih memahami dan memilih rangka kerja RPC yang sesuai untuk projek mereka sendiri.
gRPC ialah rangka kerja RPC sumber terbuka berprestasi tinggi yang dibangunkan oleh Google, berdasarkan protokol HTTP/2 dan protokol bersiri Protocol Buffers (ProtoBuf). gRPC menyediakan ciri berkuasa seperti sokongan silang bahasa, pengesahan, pengimbangan beban, dsb. Berikut ialah contoh pelayan dan pelanggan gRPC yang mudah:
Contoh kod pelayan:
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) } }
Contoh kod pelanggan:
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) }
Atas ialah kandungan terperinci Inventori rangka kerja RPC bahasa Go: Senarai lima pilihan popular. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!