インターネット技術の発展に伴い、分散システムの適用はますます普及しており、分散システムにおける重要な通信方法としてリモート プロシージャ コール (RPC) も普及しています。ますます人気が高まっており、ますます注目を集め、アプリケーションが増えています。数ある RPC フレームワークの中でも、高速で効率的なプログラミング言語である Go 言語には、RPC フレームワークの選択肢も豊富にあります。この記事では、Go 言語の RPC フレームワークを概観し、一般的な 5 つの選択肢を紹介し、読者が自分のプロジェクトに適した RPC フレームワークをよりよく理解して選択できるように、具体的なコード例を示します。
gRPC は、HTTP/2 プロトコルとプロトコル バッファー (ProtoBuf) シリアル化プロトコルに基づいて、Google によって開発された高性能のオープンソース RPC フレームワークです。 gRPC は、言語間のサポート、認証、負荷分散などの強力な機能を提供します。以下は、単純な gRPC サーバーとクライアントの例です:
サーバー コード例:
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) } }
クライアント コード例:
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) }
以上がGo 言語 RPC フレームワークの一覧: 人気のある 5 つの選択肢のリストの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。