Skip to content

A light-weight RPC implement of google protobuf RPC framework.

License

Notifications You must be signed in to change notification settings

andywang1988/sofa-pbrpc

 
 

Repository files navigation

sofa-pbrpc

Build Status

A light-weight RPC implement of google protobuf RPC framework.

Wiki: https://github.com/baidu/sofa-pbrpc/wiki

Features

  • High performace.
  • Easy to use. Refer to sample codes in './sample'.
  • Support sync call and async call. Refer to './sample/echo'.
  • Support three level (service/method/request) timeout. Refer to './sample/timeout_sample'.
  • Support transparent compression. Refer to './sample/compress_sample'.
  • Support mock test. Refer to './sample/mock_sample'.
  • Support network flow control.
  • Support auto connecting and reconnecting.
  • Support keep alive time of idle connections.
  • Support statistics for profiling.
  • Support multi-server load balance and fault tolerance.
  • Support http protocol.
  • Provide web monitor.
  • Provide python client library.

Dependings

This lib depends on boost-1.53.0 (only need header), protobuf-2.4.1, snappy and zlib:

ATTENTION: boost header is only needed when compiling the lib, but no need for user code.

Extrally, './unit-test' and './sample/mock_sample' also depends on gtest:

Build

  1. Modify the file './depends.mk' to specify depending libs.
    The necessary libs is boost, protobuf, snappy, and zlib.
  2. Run 'make' to build sofa-pbrpc.
    The default optimization level is 'O2'.
    To change it, modify the 'OPT' variable in file './Makefile'.
  3. Run 'make install' to install sofa-pbrpc.
    The default install directory is './output'.
    To change it, modify the 'PREFIX' variable in file './Makefile'.

For more details, please refer to the wiki.

Sample

For sample codes, please refer to './sample' and the wiki.

Performance

For performace details, please refer to the wiki.

Support

opensearch@baidu.com

User List

If sofa-pbrpc is used in your product, please record your user information in the belowing table with a new line, so that communication between users can be more convenient, and new features will be better notified.

company product line cluster scale owner recommendation

About

A light-weight RPC implement of google protobuf RPC framework.

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • C++ 97.1%
  • Makefile 1.0%
  • Python 0.7%
  • Perl 0.7%
  • Protocol Buffer 0.3%
  • Shell 0.2%