SRPC

High performance, low latency, lightweight enterprise-level RPC system, which supports Baidu bRPC, Tencent tRPC, thrift protocols.

Stars
1.77K
Forks
378
Open issues
20
Closed issues
51
Last release
about 1 year ago
Last commit
5 months ago
Watchers
1.77K
Total releases
9
Total commits
849
Open PRs
0
Closed PRs
254
Repo URL
Platform
License
apache-2.0
Category
Offers premium version?
NO
Proprietary?
NO
About

中文版入口


NEW !!! 👉 SRPC tools : build Workflow and SRPC projects easily.

Introduction

SRPC is an enterprise-level RPC system used by almost all online services in Sogou. It handles tens of billions of requests every day, covering searches, recommendations, advertising system, and other types of services.

Bases on Sogou C++ Workflow, it is an excellent choice for high-performance, low-latency, lightweight RPC systems. Contains AOP aspect-oriented modules that can report Metrics and Trace to a variety of cloud-native systems, such as OpenTelemetry, etc.

Its main features include:

  • Support multiple RPC protocols: SPRC, bRPC, Thrift, tRPC
  • Support multiple operating systems: Linux, MacOS, Windows
  • Support several IDL formats: Protobuf, Thrift
  • Support several data formats transparently: Json, Protobuf, Thrift Binary
  • Support several compression formats, the framework automatically decompresses: gzip, zlib, snappy, lz4
  • Support several communication protocols transparently: tcp, http, ssl, https
  • With HTTP+JSON, you can communicate with the client or server in any language
  • Use it together with Workflow Series and Parallel to facilitate the use of calculations and other asynchronous resources
  • Perfectly compatible with all Workflow functions, such as name service, upstream and other components
  • Report Tracing to OpenTelemetry
  • Report Metrics to OpenTelemetry and Prometheus
  • More features...

Installation

srpc has been packaged for Debian and Fedora. Therefore, we can install it from source code or from the package in the system.

reference: Linux, MacOS, Windows Installation and Compilation Guide

Quick Start

Let's quickly learn how to use it in a few steps.

For more detailed usage, please refer to Documents and Tutorial.

  1. example.proto
    syntax = "proto3";// You can use either proto2 or proto3. Both are supported by srpc

message EchoRequest { string message = 1; string name = 2; };

message EchoResponse { string message = 1; };

service Example { rpc Echo(EchoRequest) returns (EchoResponse); };

  1. generate code
    protoc example.proto --cpp_out=./ --proto_path=./
    srpc_generator protobuf ./example.proto ./
  2. server.cc
    #include <stdio.h>
    #include <signal.h>
    #include "example.srpc.h"

using namespace srpc;

class ExampleServiceImpl : public Example::Service { public: void Echo(EchoRequest *request, EchoResponse *response, RPCContext *ctx) override { response->set_message("Hi, " + request->name()); printf("get_req:\n%s\nset_resp:\n%s\n", request->DebugString().c_str(), response->DebugString().c_str()); } };

void sig_handler(int signo) { }

int main() { signal(SIGINT, sig_handler); signal(SIGTERM, sig_handler);

SRPCServer server_tcp;
SRPCHttpServer server_http;

ExampleServiceImpl impl;
server_tcp.add_service(&amp;impl);
server_http.add_service(&amp;impl);

server_tcp.start(1412);
server_http.start(8811);
getchar(); // press "Enter" to end.
server_http.stop();
server_tcp.stop();

return 0;

}

  1. client.cc
    #include <stdio.h>
    #include "example.srpc.h"

using namespace srpc;

int main() { Example::SRPCClient client("127.0.0.1", 1412); EchoRequest req; req.set_message("Hello, srpc!"); req.set_name("workflow");

client.Echo(&amp;req, [](EchoResponse *response, RPCContext *ctx) {
    if (ctx-&gt;success())
        printf("%s\n", response-&gt;DebugString().c_str());
    else
        printf("status[%d] error[%d] errmsg:%s\n",
                ctx-&gt;get_status_code(), ctx-&gt;get_error(), ctx-&gt;get_errmsg());
});

getchar(); // press "Enter" to end.
return 0;

}

  1. make

    These compile commands are only for Linux system. On other system, complete cmake in tutorial is recommanded.

    g++ -o server server.cc example.pb.cc -std=c++11 -lsrpc
    g++ -o client client.cc example.pb.cc -std=c++11 -lsrpc
  2. run

    Terminal 1:

    ./server

    Terminal 2:

    ./client

    We can also use CURL to post Http request:

    curl 127.0.0.1:8811/Example/Echo -H 'Content-Type: application/json' -d '{message:"from curl",name:"CURL"}'

    Output of Terminal 1:

    get_req:
    message: "Hello, srpc!"
    name: "workflow"

set_resp: message: "Hi, workflow"

get_req: message: "from curl" name: "CURL"

set_resp: message: "Hi, CURL"

Output of Terminal 2:

message: "Hi, workflow"

Output of CURL:

{"message":"Hi, CURL"}
Benchmark

  • CPU 2-chip/8-core/32-processor Intel(R) Xeon(R) CPU E5-2630 v3 @2.40GHz
  • Memory all 128G
  • 10 Gigabit Ethernet
  • BAIDU brpc-client in pooled (connection pool) mode

QPS at cross-machine single client→ single server under different concurrency

Client = 1
ClientThread = 64, 128, 256, 512, 1024
RequestSize = 32
Duration = 20s
Server = 1
ServerIOThread = 16
ServerHandlerThread = 16

QPS at cross-machine multi-client→ single server under different client processes

Client = 1, 2, 4, 8, 16
ClientThread = 32
RequestSize = 32
Duration = 20s
Server = 1
ServerIOThread = 16
ServerHandlerThread = 16

QPS at same-machine single client→ single server under different concurrency

Client = 1
ClientThread = 1, 2, 4, 8, 16, 32, 64, 128, 256
RequestSize = 1024
Duration = 20s
Server = 1
ServerIOThread = 16
ServerHandlerThread = 16

QPS at same-machine single client→ single server under different request sizes

Client = 1
ClientThread = 100
RequestSize = 16, 32, 64, 128, 256, 512, 1024, 2048, 4096, 8192, 16384, 32768
Duration = 20s
Server = 1
ServerIOThread = 16
ServerHandlerThread = 16

Latency CDF for fixed QPS at same-machine single client→ single server

Client = 1
ClientThread = 50
ClientQPS = 10000
RequestSize = 1024
Duration = 20s
Server = 1
ServerIOThread = 16
ServerHandlerThread = 16
Outiler = 1%

Latency CDF for fixed QPS at cross-machine multi-client→ single server

Client = 32
ClientThread = 16
ClientQPS = 2500
RequestSize = 512
Duration = 20s
Server = 1
ServerIOThread = 16
ServerHandlerThread = 16
Outiler = 1%

Contact

Alternative Projects

Subscribe to Open Source Businees Newsletter

Twice a month we will interview people behind open source businesses. We will talk about how they are building a business on top of open source projects.

We'll never share your email with anyone else.