前言


最近,闲来无事,自己写了一个简单的RPC框架,我把它叫做SimpleRpc。它有多简单?一共只有1400行代码。这个RPC只是作为自己试验作品,交流技术之用,当然如果你敢用,也可以放到生产环境之中,只不过要自求多福。

现在有很多开源的RPC,我用过的有ICE,thrift,grpc。我知道有很多小伙伴想阅读以上这些开源项目的源码,但是一头扎进去,难免会迷了方向,毕竟这些成熟的RPC考虑了很多东西,很容易让人陷入到某个细节不能自拔,对于理解主干反而是一种累赘。所以,我的这个SimpleRpc就是要精简精简再精简,把这些RPC的骨骼抽出来,忽略一些可用性、易用性、移植性,目的只是要小伙伴们理解RPC的主要工作流程,克服对RPC设计的恐惧。我相信,如果小伙伴们看完这个简单的不能再简单的设计后,自己也能顺手写出一个RPC。

写作思路


如果只用一篇博客写完这个SimpleRpc的实现,将会使得这个博客又臭又长,小伙伴们很难一下子全部消化掉。所以,我准备一一系列博客写完这个RPC,这样做的好处在于可以在每篇博客中详细讲一个设计要点,每个部分都成为一个单独的设计点存在,这样就使得这个设计有主次之分,有阶段性理解。

当然,我在本篇博客中附件中附上源代码,小伙伴可以去看:https://github.com/haolujun/SimpleRpc

SimpleRpc-系统边界以及整体架构

SimpleRpc-序列化与反序列化的设计与实现

SimpleRpc-网络事件响应Reactor设计模式

SimpleRpc-客户端与服务端工作模型探讨

使用样例


在进行具体介绍之前,我们先贴上客户端与服务端的样例代码,让大家熟悉一下这个rpc的使用方法。我们开发一个做加法计算的服务和客户端,客户端每次发送给服务端两个数字,服务端把相加后得到的结果返回给客户端。

客户端代码:

 #include <string>
#include "Add.h"
#include "SimpleRpc.h" int main(){
Server server(
std::string("add"),
std::string("add"),
std::string("127.0.0.1"),
std::string("")
); CalcRequest req;
req.set_a();
req.set_b();
AddRequest add_request;
AddResponse add_response;
add_request.set_req(req); for(int i = ; i < ; ++i) {
SimpleRpcClient::get_instance()->request(
server, (Request*)&add_request, (Response*)&add_response);
printf("result = %d\n", add_response.get_response().result());
} return ;
}

服务端代码:

 #include "Add.h"
#include "SimpleRpc.h" int main(){
std::string service_name("add");
SimpleRpcService<AddRequest, AddResponse, AddProcessorFactory> *service_add;
service_add = new SimpleRpcService<AddRequest, AddResponse, AddProcessorFactory>(
std::string(""), service_name);
service_add->start();
return ;

当然这里面忽略了一些额外还需要我们写的代码,我只要给各位小伙伴留一个直白印象。除了标记成红色的类之外,小伙伴还需实现AddProcessor这个类即可。AddProcessor类如下:

class AddProcessor : public Processor<AddRequest, AddResponse>{
public:
int process(AddRequest &request, AddResponse &response) {
CalcRequest req = request.get_req();
CalcResponse resp;
resp.set_result(req.a() + req.b());
response.set_response(resp);
return ;
}
}

如何用一天时间实现自己的RPC框架的更多相关文章

  1. DAX/PowerBI系列 - 关于时间系列 - 如何用脚本生成时间维度 (Generate Date Dimension)

    跟大家的交流是我的动力. :) DAX/PowerBI系列 - 关于时间系列 - 如何用脚本生成时间维度 (Generate Date Dimension) 难度: ★☆☆☆☆(1星) 适用范围: ★ ...

  2. DAX/PowerBI系列 - 关于时间系列 - 如何用脚本生成时间维度 (Generate TIME Dimension)

    DAX/PowerBI系列 - 关于时间系列 - 如何用脚本生成时间维度 (Generate TIME Dimension) 难度: ★☆☆☆☆(1星) 适用范围: ★★★★★(5星) 这个时间系列想 ...

  3. 如何用cocoapods 来管理项目中的第三方框架?

     一.安装 1.如果以前安装过,升级到10.10后工作不正常,可以先删除cocoapods $ sudo gem uninstall cocoapods ----------------------- ...

  4. 简易RPC框架-学习使用

    *:first-child { margin-top: 0 !important; } body>*:last-child { margin-bottom: 0 !important; } /* ...

  5. 第6章 RPC之道

    6.1 认识RPC 分布式.微服务的架构思维中都不能缺少 RPC 的影子 RPC(Remote Procedure Call)远程过程调用.通过网络在跨进程的两台服务器之间传输信息,我们使用的时候不用 ...

  6. 如何用docker安装laravel开发环境

    如何用docker安装laravel开发环境 看laravel框架的官方文档安装部分时,发现需要安装特别多软件,估计还有许多复杂的配置,官方推荐使用Laravel Homestead虚拟机进行安装,但 ...

  7. 如何降低90%Java垃圾回收时间?以阿里HBase的GC优化实践为例

    过去的一年里,我们准备在Ali-HBase上突破这个被普遍认知的痛点,为此进行了深度分析及全面创新的工作,获得了一些比较好的效果.以蚂蚁风控场景为例,HBase的线上young GC时间从120ms减 ...

  8. 如何用ABP框架快速完成项目(6) - 用ABP一个人快速完成项目(2) - 使用多个成熟控件框架

    正如我在<office365的开发者训练营,免费,在微软广州举办>课程里面所讲的, 站在巨人的肩膀上的其中一项就是, 尽量使用别人成熟的框架. 其中也包括了控件框架   abp和52abp ...

  9. Oracle Time Model Statistics(时间模型统计)

    Oracle数据库从10g開始,启用以时间模型统计为主.命中率为辅等性能度量指标.基于时间模型统计,主要是基于操作类型測量在数据库中花费的时间的统计信息.最重要的时间模型统计是数据库时间.或DB时间. ...

随机推荐

  1. CNN详解

    CNN详解 版权声明:本文为博主原创文章,转载请指明转载地址 http://www.cnblogs.com/fydeblog/p/7450413.html 前言 这篇博客主要就是卷积神经网络(CNN) ...

  2. 挖个坑,写一个Spring+SpringMVC+Mybatis的项目

    想挖个坑督促自己练技术,有时候想到一个项目,大概想了一些要实现的功能,怎么实现.现在觉得自己差不多能完成QQ空间的主要功能了.准备立个牌坊,写一个类似功能的网站.并且把进度放到这里来. 初步计划实现以 ...

  3. Celery基本原理探讨

    本文对Celery进行了研究,由于其实现相对比较复杂没有足够的时间和精力对各方各面的源码进行分析,因此本文根据Celery的使用方法以及实际行为分析其运行原理,并根据查阅相关代码进行了一定程度的验证. ...

  4. windows下命令行模式中cd命令无效的原因

    当我们执行cmd 想切换当前工作目录时,会发现windows下命令行模式中cd命令没有生效,到底是什么原因呢? 例如: 当我们想切换到 D:\MySql\mysql-5.7.19-winx64\bin ...

  5. 程序员也有春天之HTTP/2.0配置

    哎呀,一不小心自己的博客也是HTTP/2.0了,前段时间对网站进行了https迁移并上了CDN,最终的结果是这酱紫的(重点小绿锁,安全标示以及HTTP/2.0请求). 科普 随着互联网的快速发展,HT ...

  6. android TranslateAnimation 顶部segment分段移动动画

    这里实现的功能是从主页布局的fragment点击跳转到一个acitivity,然后顶部是一个切换的segment顶部是一个listview,点击segment分段让listview加载不同的内容.我这 ...

  7. selenium chromedriver与谷歌浏览器版本映射表 (更新至v2.32)

    ----------ChromeDriver v2.32 (2017-08-30)---------- Supports Chrome v59-61最新的ChromeDriver 2.32 支持谷歌浏 ...

  8. 转:【Java并发编程】之十:使用wait/notify/notifyAll实现线程间通信的几点重要说明

    转载请注明出处:http://blog.csdn.net/ns_code/article/details/17225469    在Java中,可以通过配合调用Object对象的wait()方法和no ...

  9. Quartz的misfire处理机制分析

    Quartz是一个特性丰富的开源的任务调度开发库,它可以很方便的集成到你的应用程序中.在Quartz中,当一个持久的触发器因为调度器被关闭或者线程池中没有可用的线程而错过了激活时间时,就会发生激活失败 ...

  10. 201521123065 《Java程序设计》第4周学习总结

    1. 本周学习总结 1.1 尝试使用思维导图总结有关继承的知识点. 1.2 使用常规方法总结其他上课内容 类设计:属性设计类型为priate并初始化. 文档注释:以/*开始,以*/结束. 继承:存在的 ...