>백엔드 개발 >Golang >gRPC Golang 사용법을 소개하는 글

gRPC Golang 사용법을 소개하는 글

PHPz
PHPz원래의
2023-04-13 09:06:331096검색

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;
}
  • syntax는 .proto 파일에서 사용되는 구문 버전을 정의합니다.
  • package는 패키지 이름을 정의합니다.
  • service는 서비스를 정의합니다.
  • rpc는 요청 입력 및 출력 반환
  • message 메시지 형식 정의

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)
    }
}
  • SayHello 메소드를 구현한 서버 구조
  • SayHello 메소드는 컨텍스트(ctx)와 HelloRequest 객체를 입력으로 받아 HelloReply 객체와 grpc.NewServer()를 통해 오류
  • 가 gRPC 서버를 생성합니다.
  • pb.RegisterGreeterServer를 사용하여 서버에 서비스를 등록합니다.
  • 서버 시작

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)
}
  • grpc.Dial 메서드를 사용하여 연결 만들기
  • GreeterClient 객체 c 만들기
  • c.SayHello 메서드를 사용하여 서비스 요청
  • 서비스 응답 인쇄

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.