gRPC는 Google에서 개발하고 오픈소스로 제공하는 고성능 다목적 오픈소스 RPC 프레임워크입니다. gRPC는 Golang을 포함한 여러 프로그래밍 언어를 지원합니다. 이번 글에서는 gRPC Golang 사용법을 소개하겠습니다.
1. gRPC 설치
gRPC Golang 개발을 하기 전에 먼저 gRPC를 설치해야 합니다. 다음 명령을 통해 설치할 수 있습니다.
go get -u google.golang.org/grpc
설치가 완료되면 gRPC의 Go 언어 코드 생성기 protoc-gen-go도 설치해야 하며, 이는 다음 명령을 통해 설치할 수 있습니다.
go get -u github.com/golang/protobuf/protoc-gen-go
2. .proto 파일
gRPC Golang을 사용할 때 개발하기 전에 먼저 .proto 파일을 정의해야 합니다. .proto 파일은 서비스 인터페이스와 메시지 형식을 정의합니다. 다음은 .proto 파일의 예입니다.
syntax = "proto3"; package helloworld; service Greeter { rpc SayHello (HelloRequest) returns (HelloReply) {} } message HelloRequest { string name = 1; } message HelloReply { string message = 1; }
3. Go 언어 코드 생성
.proto 파일이 정의된 후 protoc 도구를 사용하여 Go 언어 코드를 생성해야 합니다. 다음 명령을 통해 생성할 수 있습니다:
protoc -I helloworld/ helloworld/helloworld.proto --go_out=plugins=grpc:helloworld
생성된 Go 언어 코드는 지정된 디렉터리 helloworld에 저장됩니다.
4. 서버 구현
Go 언어 코드를 생성한 후에는 서비스를 구현해야 합니다. 다음은 SayHello 메소드를 구현한 서비스의 예입니다.
package main import ( "context" "fmt" "net" "google.golang.org/grpc" pb "github.com/your_username/helloworld" ) const ( port = ":50051" ) type server struct{} func (s *server) SayHello(ctx context.Context, in *pb.HelloRequest) (*pb.HelloReply, error) { return &pb.HelloReply{Message: "Hello " + in.Name}, nil } func main() { lis, err := net.Listen("tcp", port) if err != nil { fmt.Printf("failed to listen: %v", err) return } s := grpc.NewServer() pb.RegisterGreeterServer(s, &server{}) fmt.Printf("server listening at %v", lis.Addr()) if err := s.Serve(lis); err != nil { fmt.Printf("failed to serve: %v", err) } }
5. 클라이언트 구현
클라이언트를 구현하여 호출할 수 있습니다. 서비스. 다음은 SayHello 메서드 호출을 구현하는 클라이언트의 예입니다.
package main import ( "context" "log" "os" "time" "google.golang.org/grpc" pb "github.com/your_username/helloworld" ) const ( address = "localhost:50051" defaultName = "world" ) func main() { // Set up a connection to the server. conn, err := grpc.Dial(address, grpc.WithInsecure(), grpc.WithTimeout(10*time.Second)) if err != nil { log.Fatalf("did not connect: %v", err) } defer conn.Close() c := pb.NewGreeterClient(conn) // Contact the server and print out its response. name := defaultName if len(os.Args) > 1 { name = os.Args[1] } 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) }
Six, 프로그램 컴파일 및 실행
다음 명령을 사용하여 서버 및 클라이언트 프로그램을 컴파일합니다.
go build -o server ./server/main.go go build -o client ./client/main.go
서버 프로그램 실행:
./server
클라이언트 프로그램 실행:
./client
7. 요약
이 글에서는 gRPC 및 protoc-gen-go 설치, .proto 파일 생성, Go 언어 코드 생성, 서버 및 클라이언트 구현, 마지막으로 프로그램 컴파일 및 실행 등 gRPC Golang 사용 방법을 소개합니다. gRPC Golang은 분산 시스템의 서비스 간 통신에 사용할 수 있는 고성능 다목적 RPC 프레임워크를 제공합니다.
위 내용은 gRPC Golang 사용법을 소개하는 글의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!