博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
分布式文件系统KFS源码阅读与分析(三):RPC实现机制(MetaServer端)
阅读量:6364 次
发布时间:2019-06-23

本文共 1963 字,大约阅读时间需要 6 分钟。

分布式文件系统KFS的MetaServer和Client采用服务器/客户端模型,MetaServer和Client之间的通讯是通过RPC机制来实现的。这里介绍下KFS中MetaServer端的RPC实现机制。

1. RPC相关类

下图所示为MetaServer端的RPC相关实现类:

1、NetDispatch

(1)启动MetaServer端的epoll主循环;

(2)通过调用gNetDispatch.Start(gClientPort, gChunkServerPort),在指定的端口监听来自Client和ChunkServer的RPC请求:

  • 启动ClientManager的接收者acceptor;
  • 启动ChunkServerFactory的接收者acceptor。

2、NetManager

(1)通过epoll机制,维护一组NetConnection对象;当NetConnection状态发生变化时,调用其中的KfsCallbackObj的回调函数;

(2)同时实现了一个定时器机制。

3、NetConnection

(1)将KfsCallbackObj和TcpSocket关联起来,代表来自客户端的一个连接;

(2)当TCP连接的状态发生变化时,KfsCallbackObj的回调函数将会被调用执行。

4、Acceptor

(1)从Client/ChunkServer接收新的连接,然后创建一个新的NetConnection与这个新连接关联起来。NetConnection中含有相关的ClientSM/ChunkServer KfsCallbackObj,而ClientSM/ChunkServer KfsCallbackObj通过IAcceptorOwner的CreateKfsCallbackObj()方法被创建;

(2)继承于KfsCallbackObj,回调函数是Acceptor::RecvConnection:

  • 一个Acceptor含有一个相关的NetConnection;
  • 一个Acceptor含有一个成员变量mAcceptorOwner指向ClientManager或ChunkServerFactory。
5、IAcceptorOwner
(1)维护一个Acceptor,并提供CreateKfsCallbackObj()接口创建KfsCallbackObj。
6、ClientManager
(1)继承于IAcceptorOwner;
(2)含有一个Acceptor,用于接收新的连接;
(3)含有CreateKfsCallbackObj()方法,用于返回一个ClientSM KfsCallbackObj与Client的连接请求关联起来。
7、ChunkServerFactory
(1)继承于IAcceptorOwner;
(2)含有一个Acceptor,用于接收新的连接;
(3)含有CreateKfsCallbackObj()方法,用于返回一个ChunkServer KfsCallbackObj与ChunkServer的连接请求关联起来。
8、ClientSM
(1)继承于KfsCallbackObj,回调函数是HandleRequest();
(2)用于与一个Client连接建立关系,处理Client发起的请求。
9、ChunkServer
(1)继承于KfsCallbackObj,回调函数是HandleHello();
(2)用于与一个ChunkServer连接建立关系,处理ChunkServer发起的hello消息。
10、KfsCallbackObj
(1)调用SetHandler()设置回调函数,当外部事件发生时,调用HandleEvent()进行回调处理。

2. 请求处理过程

下图所示为MetaServer端的RPC请求处理过程的时序图:

KFS启动时,将RPC的各种请求操作映射到不同的处理函数上:kfs_startup (startup.cc) > initialize_request_handlers (request.cc) > setup_handlers (request.cc)。

更进一步来分析一下,以KfsClient与MetaServer之间的RPC为例,KfsClient与MetaServer建立RPC连接后,ClientSM作为KfsClient与MetaServer之间RPC请求的代理,ClientSM负责接收并转发来自KfsClient的各种不同Request信息,处理后负责向KfsClient写Response信息,RPC请求的处理过程如下图所示(以MetaLookup为例,图中详细展示了相关的类及方法的调用关系):

转载地址:http://wjama.baihongyu.com/

你可能感兴趣的文章
C# Web Forms - Using jQuery FullCalendar
查看>>
H5移动端知识点总结
查看>>
Sublime-Text-2-pydocstring --- 自动生成python docstring的插件
查看>>
初涉c#设计模式-Observer Pattern-从公司管理系统删单提醒开始
查看>>
UNIX进程环境
查看>>
命名空间和定义和使用
查看>>
学习面试题Day03
查看>>
我最喜欢的jQuery插件模板
查看>>
【云计算】Docker 多进程管理方案
查看>>
C/C++中经常使用的字符串处理函数和内存字符串函数
查看>>
[LeetCode] Best Meeting Point 最佳开会地点
查看>>
基于InstallShield2013LimitedEdition的安装包制作
查看>>
【转】从Shell脚本内部将所有标准输出及标准错误显示在屏幕并同时写入文件的方法...
查看>>
python内存管理
查看>>
iOS开发小技巧--利用MJExtension解决数据结构复杂的模型转换
查看>>
Python中的图形库
查看>>
Linux操作系统分析 ------------------中国科技大学
查看>>
Apache多站点实现原理和配置
查看>>
javascript类型系统——包装对象
查看>>
Android4.4中不能发送SD卡就绪广播
查看>>