mirror of
https://github.com/zeromicro/go-zero.git
synced 2026-06-22 09:51:56 +08:00
Co-authored-by: kevin <wanjunfeng@gmail.com> Co-authored-by: Copilot <223556219+Copilot@users.noreply.github.com>
2.8 KiB
2.8 KiB
예제 01: 기본 RPC 서비스
이 예제는 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)을 수정하세요.