Create a gRPC server in Go by defining a proto service, generating Go code, and running a server that listens on a TCP port.
package main
import (
"context"
"log"
"net"
"google.golang.org/grpc"
)
type server struct {
unimplementedServiceServer
}
func (s *server) Method(ctx context.Context, req *Request) (*Response, error) {
return &Response{Message: "Hello"}, nil
}
func main() {
lis, err := net.Listen("tcp", ":50051")
if err != nil {
log.Fatalf("failed to listen: %v", err)
}
s := grpc.NewServer()
RegisterServiceServer(s, &server{})
log.Fatal(s.Serve(lis))
}
- Define your service and methods in a
.protofile. - Generate Go code by running
protoc --go_out=. --go-grpc_out=. your_file.proto. - Implement the generated server interface in your Go code.
- Create a new gRPC server with
grpc.NewServer()and register your service. - Start listening on a port with
s.Serve(lis).