Skip to content

Apra487/go-grpc

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

3 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Basic Go gRPC Server and Client

This is a simple gRPC server and client written in Go. It is based on the gRPC Quickstart and gRPC Basics: Go .

We have implemented a the following functionality:

  • simple RPC
  • server-side streaming RPC
  • client-side streaming RPC
  • bidirectional streaming RPC

Setting up a gRPC-Go project

  1. Create a new directory for your project and cd into it
mkdir basic-go-grpc
cd basic-go-grpc
mkdir client server proto
  1. Installing the gRPC Go plugin
go install google.golang.org/protobuf/cmd/protoc-gen-go@v1.28

go install google.golang.org/grpc/cmd/protoc-gen-go-grpc@v1.2

export PATH="$PATH:$(go env GOPATH)/bin"
  1. Initialize a Go module
go mod init github.com/your_username/basic-go-grpc

go mod tidy
  1. Create the proto file with the required services and messages in the proto directory

  2. Generate .pb.go files from the proto file

depending on what path you mention in your greet.proto file, you will either run this -

protoc --go_out=. --go-grpc_out=. proto/greet.proto

OR this -

protoc --go_out=. --go_opt=module=github.com/Apra487/basic-go-grpc --go-grpc_out=. --go-grpc_opt=module=githu
b.com/Apra487/basic-go-grpc proto/greet.proto
  1. Create the server and client directories and create the main.go files with necessary controllers and services

Running the application

  1. Install the dependencies
go mod tidy
  1. Run the server
go run server/main.go
  1. Run the client
go run client/main.go

License



About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages