Mudo C++网络库第八章学习笔记

muduo网络库的设计与实现

  • muduo是基于Reactor模式的C++网络库;
Reactor的关键结构
  • Reactor最核心的是事件分发机制, 即将IO multiplexing拿到IO事件分发给各个文件描述符(fd)的事件处理函数;
  • 每个Channel对象自始至终只负责一个文件描述符(fd)的IO事件分发, 但它并不拥有这个fd, 也不会在析构的时候关闭这个fd;
TimerQueue定时器
  • 用timerfd给EventLoop加上定时器功能(和处理IO事件相同的方式来处理定时), 这样的代码一致性更好;
TCP No Delay 和 TCP keepalive
  • TCP No Delay 和 TCP keepalive都是常用的TCP选项, 前者的作用是禁用Nagle算法, 避免连续发包出现延迟, 这对编写低延迟网络服务很重要;
    • TCP keepalive的作用是定期检查TCP连接是否还存在;
    • 如果有应用层心跳的话, TCP keepalive不是必需的;
高水位回调和低水位回调
  • muduo使用HighWaterMarkCallback和WriteComleteCallback;
  • muduo库的event loop pool由EventLoopThreadPool类表示;
  • muduo库的TcpClient具备TcpConnection断开之后重新连接的功能, 加上Connector具有反复尝试连接的功能, 因此客户端和服务器的启动顺序无关紧要;
epoll
  • epoll是Linux独有的高效的IO multiplexing机制, 它与poll的不同是:
    • poll每次返回整个文件描述符数组, 用户要遍历数组以找到那些文件描述符上有IO事件;
    • 而epoll_wait返回的是活动fd的列表, 需要遍历的数组通常会小得多;
    • 在并发连接数较大而活跃连接比例不高时, epoll比poll更高效;

转载于:https://www.cnblogs.com/longjiang-uestc/p/9842243.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值