Setup
Install grpc-tools and google-protobuf as node module
Folder structure will be as below:
data:image/s3,"s3://crabby-images/634fb/634fbb3068f9ed5e986fa4f84f5d961bb3fc6ab0" alt=""
Let’s create a dummy proto file
data:image/s3,"s3://crabby-images/9b0de/9b0de6827c667531e2b0a66927759306d56317ba" alt=""
Its time to generate the code from the proto file. Let’s use the command that we have used in our previous blog of Protocol Buffers.
GRPC_TOOLS_PLUGIN="$HOME/AppData/Roaming/npm/grpc_tools_node_protoc_plugin.cmd" && C:/Users/deepak.sood/Downloads/protoc-3.13.0-win64/bin/protoc.exe -I=. ./proto/*.proto --js_out=import_style=commonjs,binary:./server --grpc_out=./server --plugin=protoc-gen-grpc=$GRPC_TOOLS_PLUGIN
#I ran this command on gitbash
This command will generate the below files:
data:image/s3,"s3://crabby-images/ccd2f/ccd2f7ff36d5dca073eafa705fe76fb191d42c94" alt=""
Server Setup
It’s time to setup a gRPC server with no service on it and we will start out server on a specific node.
Let’s create an index.js inside the server. But before that install grpc module
npm install grpc
data:image/s3,"s3://crabby-images/2d5b7/2d5b7cc8eac75543c88ad593238195369c92e941" alt=""
Our server is up and running on the defined port now.
Client Setup
In this we will connect our client to the server and will start our client on a specific port.
data:image/s3,"s3://crabby-images/4839f/4839f6491eb4949dbe68a7fb22cdcde485db49ce" alt=""
Unary API
- Unary RPC calls are the basic Request/Response that everyone is familiar with
data:image/s3,"s3://crabby-images/0e61b/0e61b5267c4684ac21d275019f22af1049c100f1" alt=""
- The client will send one message to the server and will receive one response from the server
- Unary RPC calls are the most commonly used API calls
– They are suited when the data is small - In gRPC Unary calls are defined using Protocol Buffers
- For each RPC call we have to define a “Request” message and a “Response” message
Let’s create a “Unary” Greet API in which:
- Our message is Greeting and contains firstname and lastname string field
- It will take a GreetRequest that contains a Greeting
- It will return a GreetResponse that contains a result string
Step 1 – Creating our proto
data:image/s3,"s3://crabby-images/5c104/5c104267576cdc1efcab0f8d2d620ba1ae902671" alt=""
Step 2 – Generating code from the proto file
GRPC_TOOLS_PLUGIN="$HOME/AppData/Roaming/npm/grpc_tools_node_protoc_plugin.cmd" && C:/Users/deepak.sood/Downloads/protoc-3.13.0-win64/bin/protoc.exe -I=. ./protos/greet.proto --js_out=import_style=commonjs,binary:./server --grpc_out=./server --plugin=protoc-gen-grpc=$GRPC_TOOLS_PLUGIN
data:image/s3,"s3://crabby-images/9b136/9b1362d02b7c2583b9996ffd37d597b191f03d54" alt=""
data:image/s3,"s3://crabby-images/464a9/464a96a4368c9ed13773c7dbddf77463f3a460d4" alt=""
Step 3 – Server Implementation
In this:
- We will implement a Unary Greet RPC
- We will hook our new GreetService to our Server
- We will start our server
We would require the files generated in the implementation of our server. Therefore, we will import those files in the server file.
data:image/s3,"s3://crabby-images/e7c22/e7c2226ae74dfe794fecbd7f3b655e26c3128c85" alt=""
data:image/s3,"s3://crabby-images/822b2/822b2a2e36fd96b4d6856bfebad5dae778f22c5a" alt=""
We are not done yet, we need to add the service now.
data:image/s3,"s3://crabby-images/a678b/a678b0f9085e6aef0d417a7ba3eb202d5079eb2c" alt=""
Along with this we need to pass few other things for it to work i.e the RPC methods that we will be calling.
data:image/s3,"s3://crabby-images/1c83c/1c83c2ae6734dbdbc5e6b795a2b5120794d580bd" alt=""
var greets = require('../server/protos/greet_pb');
var service = require('../server/protos/greet_grpc_pb');
var grpc = require('grpc');
/*
Implementing the greet RPC method
*/
// this should be the same name as our API as present in greet_grpc_pb file
function greet(call, callback){
// creating the actual greeting response
var greeting = new greets.GreetResponse();
//now we have our greet response, so let's now construct the response
// call is used as it will have all the information from line 11 when called
//getGreeting is from the GreetRequest object
greeting.setResult(
"Hello" + call.getGreeting().getFirstName()
)
callback(null, greeting); // passed in the greeting to be passed on to the client
}
function main(){
var server = new grpc.Server();
server.addService(service.GreetServiceService, {greet: greet})
server.bind("127.0.0.1:50051", grpc.ServerCredentials.createInsecure());
server.start();
console.log("Server running on port 127.0.0.1:50051")
}
main();var greets = require('../server/protos/greet_pb');
var service = require('../server/protos/greet_grpc_pb');
var grpc = require('grpc');
/*
Implementing the greet RPC method
*/
// this should be the same name as our API as present in greet_grpc_pb file
function greet(call, callback){
// creating the actual greeting response
var greeting = new greets.GreetResponse();
//now we have our greet response, so let's now construct the response
// call is used as it will have all the information from line 11 when called
//getGreeting is from the GreetRequest object
greeting.setResult(
"Hello" + call.request.getGreeting().getFirstName()
)
callback(null, greeting); // passed in the greeting to be passed on to the client
}
function main(){
var server = new grpc.Server();
server.addService(service.GreetServiceService, {greet: greet})
server.bind("127.0.0.1:50051", grpc.ServerCredentials.createInsecure());
server.start();
console.log("Server running on port 127.0.0.1:50051")
}
main();var greets = require('../server/protos/greet_pb');
var service = require('../server/protos/greet_grpc_pb');
var grpc = require('grpc');
/*
Implementing the greet RPC method
*/
// this should be the same name as our API as present in greet_grpc_pb file
function greet(call, callback){
// creating the actual greeting response
var greeting = new greets.GreetResponse();
//now we have our greet response, so let's now construct the response
// call is used as it will have all the information from line 11 when called
//getGreeting is from the GreetRequest object
greeting.setResult(
"Hello" + call.getGreeting().getFirstName()
)
callback(null, greeting); // passed in the greeting to be passed on to the client
}
function main(){
var server = new grpc.Server();
server.addService(service.GreetServiceService, {greet: greet})
server.bind("127.0.0.1:50051", grpc.ServerCredentials.createInsecure());
server.start();
console.log("Server running on port 127.0.0.1:50051")
}
main();
Let’s test this now:
data:image/s3,"s3://crabby-images/7e8fa/7e8fa530a112dedb4e7648cc9fa8719d6cbbd3aa" alt=""
Step 4 – Client Implementation
We will test our client against the server running.
Let’s import the files as we did in server implementation.
data:image/s3,"s3://crabby-images/b0555/b0555763cf738cac7614d3916d7a01c46a6c72b0" alt=""
The second step would be to create a greet request.
data:image/s3,"s3://crabby-images/5d41f/5d41fe165228d07bc05258ac1c427b9d916cf1da" alt=""
var grpc = require('grpc');
var greets = require('../server/protos/greet_pb');
var service = require('../server/protos/greet_grpc_pb');
function main(){
console.log('Hello from Client');
var client = new service.GreetServiceClient(
'localhost:50051',
grpc.credentials.createInsecure()
)
console.log('client', client)
// we code here later
var request = new greets.GreetRequest();
//creating the actual greeting as we did for protobuf in previous blog
//refer line 15 of proto file
//created a protocol buffer greeting message
var greeting = new greets.Greeting();
greeting.setFirstName("Deepak")
greeting.setLastName("Sood")
//set the greeting
request.setGreeting(greeting);
//setting up the client now and calling the greet from the server which knows what should be the request and response
client.greet(request, (error, response)=>{
if(!error){
console.log("Greeting response: "+ response.getResult());
}else{
console.error(error)
}
})
}
main()
It’s time to run our server and client.
data:image/s3,"s3://crabby-images/817bd/817bd2c894368e4db43a7de8cc18cd125e08f7d3" alt=""
Let’s see what happens when we stop our server
data:image/s3,"s3://crabby-images/a06f0/a06f005b59e24ee1c30ebf59a78a75c9edbacf88" alt=""