muduo源代码分析--Reactor在模型muduo使用(两)
一. TcpServer分类:
管理所有的TCP客户连接,TcpServer对于用户直接使用,直接控制由用户生活。
用户只需要设置相应的回调函数(消息处理messageCallback)然后TcpServer::start()就可以。
主要数据成员:
boost::scoped_ptr<Accepter> acceptor_; 用来接受连接
std::map<string,TcpConnectionPtr> connections_; 用来存储全部连接
connectonCallback_,messageCallback_,writeCompleteCallback_,用来接受用户注冊的回调函数
EventLoop* loop; 接受连接的事件循环
主要功能函数:
set*Callbak() 注冊用户回调函数
newconnection() 须要在构造函数内将其注冊给Acceptor。当Acceptor接受一个连接之后回调该函数。在本函数内部新建一个connection对象,并将 *Callback_注冊给新建的 Connection 对象。
最后,从线程池取出一个线程做I/O线程,在该I/O线程的 EventLoop 的 runInLoop() 中传入 TcpConnection::connectEstablished(). 由于必定不在一个线程中,在runInLoop()中调用EventLoop::quueInLoop(),将TcpConnection::connectEstablished()增加pendingFunctors.
二. Acceptor类:
负责监听连接请求,接收连接并将新的连接返回给TcpServer。
Acceptor主要是供TcpServer使用的,其生命期由后者控制。
一个Acceptor相当于持有服务端的一个listenning socket描写叙述符。该socket能够accept多个TCP客户连接,。
主要数据成员:
EventLoop* loop_;
Socket acceptSocket_;封装了socket等,用来监听
Channel acceptChannel_;Acceptor通过Channel向Poller注冊事件,EventLoop通过Channel分发回调Acceptor对应的事件处理函数。
boost::function<void(sockfd,InetAddress&)>NewConnectionCallback_ , 连接请求接收之后,通过其回调TcpServer::newconnection().
主要功能函数:
listen(),调用Socket::listen()開始监听。同一时候。调用Channel::enableReading()向Poller注冊可读事件,有数据可读代表新来了连接请求。
handleRead(),在构造函数中将其注冊给Channel::readCallback_。
当Poller发现属于Acceptor的Channel的可读事件时,在EventLoop中会驱动Channel::handleEvent()-->Channel::handleEventWithGuard()进行事件分发,调用readCallback回调 Acceptor::handlRead(),在其内调用Socekt::accept(),再回调TcpServer::newconnection(),将新连接的sockfd传回给TcpServer。
服务端监听及接受连接的流程:
向Poller注冊监听事件的主线调用流程,TcpServer::start()-->EventLoop::runInLoop(Acceptor::listen())-->Channel::enableReading()-->Channel::update(this)-->EventLoop::updateChannel(Channel*)-->Poller::updateChannel(Channel*)
接受连接,当Poller::poll()发现有事件就绪,通过 Poller::fillActiveChannel() 将就绪事件相应的 Channel 增加 ActiveChannelList,
EventLoop::loop()-->Poller::poll()-->Poller::fillActiveChannel(),loop()-->Channel::handleEvent()->Acceptor::handleRead()->TcpServer::newConnection()->EventLoop::runInLoop(bind(&TcpConnection::connectEstablished))->EventLoop::queueInLoop()->EventLoop::loop()->EventLoop::doPendingFunctors()->TcpConnection::connectEstablished()。
三. Connection类:
用于管理一个详细的TCP客户连接,完毕用户指定的连接回调connectionCallback。
TcpConnection构造时接收參数有TCP连接的描写叙述符sockfd,服务端地址localAddr,client地址peerAddr。并通过Socket封装sockfd。
且採用Channel管理该sockfd,
主要数据成员:
enum StateE { kDisconnected, kConnecting, kConnected, kDisconnecting };分别表示已断开,正在连接,已连接。正在断开。
scoped_ptr<Socket> socket_;封装该连接的socket
scoped_ptr<Channel> channel_;连接能够通过该channel向Poller注冊该连接的读写等事件。连接还要向Channel注冊TcpConection的可读/可写/关闭/出错系列回调函数。用于Poller返回就绪事件后Channel::handleEvent()运行对应事件的回调。
boost::function<void()> **Callback_,在TcpServer::newconnection()中创建TcpConnection时,就会将TcpServer中的各种处理函数注冊给对应的 TcpConnection::*Callback_ 。
Buffer inputBuffer_,outputBuffer_。输入输出的缓冲。
主要功能函数:
handle{Read(),Write(),Close(),Error()},处理连接的各种事件,会由Channel::handleEvent()依据Poller返回的详细就绪事件分发调用对应的TcpConnection::handle**().
connectEstablished(),设置连接的状态为kConnected,将channel_进行绑定,调用channel::enableReading()向Poller注冊读事件,最后回调connectionCallback_会回调TcpServer中对应的回调函数。通常会在TcpServer中继续回调用户传进来的回调函数。
send(),sendInLoop(),send()有几个重载都是进行发生数据,send()-->sendInLoop(),后者中检測输出buffer中没有数据排队就直接写,假设没有写完,或者outbuffer中有数据排队则将数据追加到outbuffer中,然后调用channel::enableWriting()向Poller注冊写事件。
TcpConnection::setTcpNoDelay()->socketopt(..,TCP_NODELAY..)来关闭Nagle算法。
发送数据流程:
TcpConnection::send(string& message)->EventLoop::runInLoop(bind(&TcpConnection::sendInLoop(string& message))->EventLoop::doPendingFunctors()->TcpConnection::sendInLoop(string& message)保证线程安全的消息发送。后经write系统调用来发送信息。
什么时候Poller当返回一个连接写或读就绪事件。类回调过程似Acceptor连接验收过程。
muduo源代码分析--Reactor在模型muduo使用(两)的更多相关文章
- muduo源代码分析--Reactor模式在muduo中的使用
一. Reactor模式简单介绍 Reactor释义"反应堆",是一种事件驱动机制.和普通函数调用的不同之处在于:应用程序不是主动的调用某个API完毕处理.而是恰恰相反.React ...
- muduo源代码分析--我对muduo的理解
分为几个模块 EventLoop.TcpServer.Acceptor.TcpConnection.Channel等 对于EventLoop来说: 他仅仅关注里面的主驱动力,EventLoop中仅仅关 ...
- ActiveMQ的安全机制使用及其源代码分析 [转]
ActiveMQ是目前较为流行的一款开源消息服务器.最近在项目开发中,需要为ActiveMQ开发基于IP的验证和授权机制,因此,对ActiveMQ的安全机制进行了了解,以下将介绍ActiveMQ的安全 ...
- 【Netty源码分析】Reactor线程模型
1. 背景 1.1. Java线程模型的演进 1.1.1. 单线程 时间回到十几年前,那时主流的CPU都还是单核(除了商用高性能的小机),CPU的核心频率是机器最重要的指标之一. 在Java领域当时比 ...
- Netty源码分析之Reactor线程模型详解
上一篇文章,分析了Netty服务端启动的初始化过程,今天我们来分析一下Netty中的Reactor线程模型 在分析源码之前,我们先分析,哪些地方用到了EventLoop? NioServerSocke ...
- MyBatis架构设计及源代码分析系列(一):MyBatis架构
如果不太熟悉MyBatis使用的请先参见MyBatis官方文档,这对理解其架构设计和源码分析有很大好处. 一.概述 MyBatis并不是一个完整的ORM框架,其官方首页是这么介绍自己 The MyBa ...
- 服务器程序源代码分析之三:gunicorn
服务器程序源代码分析之三:gunicorn 时间:2014-05-09 11:33:54 类别:网站架构 访问: 641 次 gunicorn是一个python web 服务部署工具,类似flup,完 ...
- Hadoop源代码分析
http://wenku.baidu.com/link?url=R-QoZXhc918qoO0BX6eXI9_uPU75whF62vFFUBIR-7c5XAYUVxDRX5Rs6QZR9hrBnUdM ...
- Spark SQL源代码分析之核心流程
/** Spark SQL源代码分析系列文章*/ 自从去年Spark Submit 2013 Michael Armbrust分享了他的Catalyst,到至今1年多了,Spark SQL的贡献者从几 ...
随机推荐
- SDK应该包括什么东西
作者:朱金灿 来源:http://blog.csdn.net/clever101 如果让你设计和开发一个SDK(软件二次开发包),你认为里面应该有什么东西?首先接口文件和库文件之类是必不可少的,否则别 ...
- [AngularJS] Using an AngularJS directive to hide the keyboard on submit
Pleasea refer to Link <form ng-submit="foo()" handle-phone-submit> <input type=&q ...
- Xavier Initialization 的理解与推导(及实现)
在 caffe mnist tutorial 的实现中,有如下的语句: weight_filter = {type: "xavier"}; 随后的解释中指出,本实现将使用 xavi ...
- 并查集(disjoint set)的实现及应用
这里有一篇十分精彩.生动的 并查集详解 (转): "朋友的朋友就是朋友"⇒ 传递性,建立连通关系 disjoint set,并查集(一种集合),也叫不相交集,同时也是一种树型的数据 ...
- 关于win10输入法ctrl+shift+f和idea组合键冲突的解决办法。
先Ctrl+F,按住Ctrl,再按Shift+F. 因为win10的输入法热键无法关闭(在后期的版本中好像可以了,不过没更新),在IEDA中ctrl+shift+f组合键没法使用,可以按如下按键组合使 ...
- 积跬步,聚小流------java获取图片的尺寸
在一篇文章中获取到通过例如以下两种方式进行获取: 1.使用ImageReader进行获取: 2.使用BufferedImage进行获取: 而且经过验证ImageReader进行操作的耗时远远低于Buf ...
- iOS开发webView的使用一
#import "ViewController.h" @interface ViewController () @property (weak, nonatomic) IBOutl ...
- php 模拟post的新发现,重点在最后的新方法
最近两天项目需要,由于服务器正在开发,客户端进度稍快一些,没有服务器进行联调.因此我重操旧业,用PHP快速的写了一些web页面,算是当测试桩程序了,七八个web接口,基本上5到6个小时搞定了.由于当前 ...
- TrustedBSD Mandatory Access Control Framework分析
本文为CoryXie原创译文,转载及有任何问题请联系cory.xie#gmail.com. 本文分析FreeBSD 10.0[ http://xrefs.info/freebsd-10.0/ ]的MA ...
- 小强的HTML5移动开发之路(52)——jquerymobile中的触控交互
当使用移动设备进行触控操作时,最常用的就是轻击.按住屏幕或者手势操作,jQuery Mobile可以通过绑定的触控事件来响应使用者的特定触控行为. 一.轻击与按住 直接上代码(一切皆在代码中,细细品吧 ...