分布式 RPC 系统 minirpc

码农软件 · 软件分类 · RPC/XMLRPC项目 · 2019-04-11 16:12:02

软件介绍

minirpc 是基于 protobuf 的分布式 RPC 系统。

1. rpc server端提供的service可以是so库文件方式存在,可以使用libloader工具增加到server上。
2. rpc server会将自己所提供的服务注册到agent上。
3. agent服务中心采用去中心化的方式运行,通过加入组播实现rpc server的服务列表管理和运行状态的准实时展现。
4. rpc client可以使用需要调用的server名称(字符串服务名),向agent中心获取提供此类服务的rpc server,之后连接rpc server实现数据传输和业务处理。

5. rpc server单进程每秒处理142000个请求包(intel i5 cpu),可以参考统计页面的Package TPS显示。

------------------------------------------------------------------

rpc 具体业务实现lib库编写方式:

#include "rpc_serverobserver.h"
#include "echo.pb.h"
#include "common/clogwriter.h"
#include <unistd.h>
extern "C" {
    int echo_Init(CRpcSerObserver* aRpcServer);
}
class LibEchoServiceImpl : public echo::EchoService {
    virtual void Echo(::google::protobuf::RpcController* controller,
                      const ::echo::EchoRequest* request,
                      ::echo::EchoResponse* response,
                      ::google::protobuf::Closure* done) {
        response->set_response(request->message()+" lib_rpc_server_echo_hello");
        if (done) {
            done->Run();
        }
    }
    virtual void Dummy(::google::protobuf::RpcController* controller,
                       const ::echo::DummyRequest* request,
                       ::echo::DummyResponse* response,
                       ::google::protobuf::Closure* done) {
        if (done) {
            done->Run();
        }
    }
};
int echo_Init(CRpcSerObserver* aRpcServer) {
    DEBUG(LL_WARN, "echo_Init Begin.");
    RPCREGI(aRpcServer, LibEchoServiceImpl);
    return 0;
}

------------------------------------------------------------------

agent启动方式:

cd agent

[w@localhost agent]$./miniagent -d

打开agent的运行页面观察运行状态,默认端口是15218.

http://serverip:15218

rpc server启动方式:

[w@localhost protobuf]$ ./rpc_server_basic  -p 9987 -s ECHO -d
[w@localhost protobuf]$ ./rpc_server_basic  -p 9988 -s ECHO1 -d      
[w@localhost protobuf]$ ./rpc_server_basic  -h
=====================================
  使用方法: RpcServer [参数选项][-c 配置文件]
  参数选项描述:
  -p 监听端口 程序启动时绑定的监听端口。
  -s 服务名称 程序启动时提供的服务名称。
  -c 配置文件。
  -d 后台运行  守护进程方式运行。
  -l 日志级别  日志级别见如下描述:
               1. 错误日志;
               2. 警告日志;
               3. 通知日志;
               4. 重要的提示性日志;
               5. 打印关键变量的值;
               6. 开发人员的调试日志;
               7. 打开所有的日志。
  -v           输出版本信息。
  -h           输出运行帮助信息。
  启动实例:   RpcServer  -p 9090 -c RpcServer.ini -l 2 -d
=====================================

运行动态库加载工具,向服务BasicServer增加libecho.so提供的服务。

[w@localhost protobuf]$ ./rpc_libloader BasicServer load libecho.so

create success
load resp: libecho.so load success, method list:  echo.EchoService.Echo echo.EchoService.Dummy
load requ: libecho.so
load success
[w@localhost protobuf]$ ./rpc_libloader BasicServer load libecho2.so
create success
load resp: libecho2.so load success, method list:  echo2.EchoService.Echo echo2.EchoService.Dummy

参考:
代码中你会看到一些类似的开源代码。本项目中的一些代码来自如下开源软件。
haproxy
cxxtools
thrift
protobuf
kamailio
sems
fastrpc
redis
putty等。

谢谢以上开源软件的开发者们。

请不要拍砖,如果你觉得不可使用,可以选择thrift等其他rpc软件。

本文地址:https://codercto.com/soft/d/3357.html

Perl语言入门 第六版(中文版)

Perl语言入门 第六版(中文版)

Randal L.Schwartz、brian d foy、Tom Phoenix / 盛春 / 东南大学出版社 / 2012-3 / 62.00元

《Perl语言入门(第6版)(中文版)》根据作者施瓦茨、福瓦、菲尼克斯从1991年开始的教学经验积累汇聚而成,多年来十分畅销。此次第六版涵盖了最新的Perl5.14版本的变化。《Perl语言入门(第6版)(中文版)》每章都包含若干习题,帮助你巩固消化刚学到的知识。也许其他书籍只是想着灌输Perl编程的条条框框,但《Perl语言入门(第6版)(中文版)》不同,我们希望把你培养成一名真正的Perl程序......一起来看看 《Perl语言入门 第六版(中文版)》 这本书的介绍吧!

CSS 压缩/解压工具
CSS 压缩/解压工具

在线压缩/解压 CSS 代码

html转js在线工具
html转js在线工具

html转js在线工具

HEX HSV 转换工具
HEX HSV 转换工具

HEX HSV 互换工具