-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathkey_value_layer.cc
48 lines (39 loc) · 1.2 KB
/
key_value_layer.cc
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
#include <iostream>
#include <memory>
#include <stack>
#include <string>
#include <gflags/gflags.h>
#include <glog/logging.h>
#include <grpcpp/grpcpp.h>
#include "kvs_server.h"
#include "KeyValueStore.grpc.pb.h"
using grpc::Server;
using grpc::ServerBuilder;
using grpc::ServerContext;
using grpc::Status;
// Key Value Store's execution (receives api calls from service layer)
// and sends responses
void run() {
// run server on localhost:50002
std::string server_address("0.0.0.0:50000");
KeyValueServer service;
ServerBuilder builder;
// listen on server address
builder.AddListeningPort(server_address, grpc::InsecureServerCredentials());
// Register as synchronous service
builder.RegisterService(&service);
// assemble server
std::unique_ptr<Server> server(builder.BuildAndStart());
std::cout << "Server listening on " << server_address << std::endl;
LOG(INFO) << "Server listening on " << server_address << std::endl;
// Keep running until shutdown signal received
server->Wait();
}
int main(int argc, char* argv[]) {
// initialize glog and gflags
google::InitGoogleLogging(argv[0]);
gflags::ParseCommandLineFlags(&argc, &argv, true);
// run server
run();
return 0;
}