Files
go-zero/tools/goctl/rpc/example/01-basic/README-ko.md
Jeonghyeon Kim 48ca7f03b5 docs: add Korean translations (#5579)
Co-authored-by: kevin <wanjunfeng@gmail.com>
Co-authored-by: Copilot <223556219+Copilot@users.noreply.github.com>
2026-06-21 13:49:20 +00:00

2.8 KiB

예제 01: 기본 RPC 서비스

English | 中文 | 한국어

이 예제는 goctl로 RPC 서비스를 생성하는 가장 간단한 예제입니다.

proto 정의

외부 import 없이 하나의 서비스와 하나의 RPC 메서드를 가진 greeter.proto 파일 하나를 사용합니다.

go_package는 전체 모듈 경로를 사용합니다.

option go_package = "example.com/demo/greeter";

생성 명령

방법 1: goctl rpc new로 빠르게 시작

# 한 번의 명령으로 완전한 RPC 프로젝트 생성
goctl rpc new greeter

이 명령은 proto 파일과 서비스 코드를 함께 생성합니다.

greeter/
├── etc
│   └── greeter.yaml
├── greeter
│   ├── greeter.pb.go
│   └── greeter_grpc.pb.go
├── greeter.go
├── greeter.proto
├── greeterclient
│   └── greeter.go
└── internal
    ├── config
    │   └── config.go
    ├── logic
    │   └── pinglogic.go
    ├── server
    │   └── greeterserver.go
    └── svc
        └── servicecontext.go

방법 2: 기존 proto에서 생성

먼저 출력 디렉터리에 go.mod를 초기화합니다.

mkdir -p output && cd output && go mod init example.com/demo && cd ..

그런 다음 코드를 생성합니다.

goctl rpc protoc greeter.proto \
  --go_out=output \
  --go-grpc_out=output \
  --zrpc_out=output \
  --go_opt=module=example.com/demo \
  --go-grpc_opt=module=example.com/demo \
  --module=example.com/demo \
  -I .

생성되는 디렉터리 구조:

output/
├── etc
│   └── greeter.yaml
├── go.mod
├── greeter
│   ├── greeter.pb.go
│   └── greeter_grpc.pb.go
├── greeter.go
├── greeterclient
│   └── greeter.go
└── internal
    ├── config
    │   └── config.go
    ├── logic
    │   └── sayhellologic.go
    ├── server
    │   └── greeterserver.go
    └── svc
        └── servicecontext.go

핵심 사항

  • 가장 단순한 시나리오입니다. proto 파일 하나, 서비스 하나, RPC 메서드 하나를 사용합니다.
  • go_package는 상대 경로가 아닌 전체 모듈 경로(example.com/demo/greeter)를 사용합니다.
  • --module 플래그는 goctl에 Go 모듈 이름을 알려줍니다. --go_opt=module=...--go-grpc_opt=module=...은 protoc에 출력 경로에서 모듈 접두사를 제거하라고 알려줍니다.
  • --zrpc_out 플래그는 goctl이 생성하는 서비스 코드의 출력 위치를 지정합니다.
  • --go_out--go-grpc_out 플래그는 protoc가 생성하는 코드의 출력 위치를 지정합니다.
  • 비즈니스 로직을 구현하려면 logic 파일(internal/logic/sayhellologic.go)을 수정하세요.