1.句柄IO框架库要处理的对象,即 IO事件,信号和定时事件,统一称为事件源。一个事件源通常和一个句柄绑在一起。句柄的作用是,当内核检测到就绪事件时,它将通过句柄来通知应用程序这一事件。Linux 下,IO事件对应的句柄就是文件描述符,信号事件对应的句柄就是信号值。2.事件多路分发器事件的到来是随机的,异步的。我们无法预知程序何时收到一个客户连接请求,亦或者收到一个暂停信号。所以程序需要循环的等待并处理事件,这就是事件循环。在事件循环中,等待事件一般使用IO复用技术来实现。IO 框架库一般将系统支持的各种IO复用系统调用封装成统一的接口,称为事件多路分发器。事件多路分发器的 demultiplex方法是等待事件的核心函数,起内部调用的是 select, poll, epoll_wait 等函数.3.事件处理器/具体事件处理器事件处理器执行事件对应的业务逻辑。它通常包含一个或者多个 handle_event 回调函数,这些回调函数在事件循环中被执行。IO框架库提供的事件处理器通常是一个接口,用户需要继承它来实现自己的事件处理器,即具体事件处理器。因此,事件处理器中的回调函数一般被声明为虚函数,以支持用户的扩展。4.ReactorReactor 是 IO 框架库的核心。它提供的几个主要方法是:handle_events.该方法执行事件循环。它重复如下过程:等待事件,然后依次处理所有就绪事件对应的事件处理器。register_handler. 该方法调用事件多路分发器的 register_event 方法来往事件多路分发器中注册一个事件。remove_handle. 该方法调用事件多路分发器的 remove_event 方法来删除事件多路分发器中的一个事件。

12.1 IO 框架库概述

12.2 Libevent 源码分析

12.Linux 高性能服务器编程 --- 高性能 IO 框架库 Libevent相关推荐

  1. Linux高性能服务器编程——书籍阅读笔记

    目录 前言 正文 第一章 1. 零拷贝函数 2. TCP/IP协议族 3. OSPF 4. ARP协议 5. RARP 6. ICMP协议 7. TCP协议 8. UDP协议 9. 封装 第四章 TC ...

  2. 《Linux高性能服务器编程》——导读

    前 言 为什么要写这本书 目前国内计算机书籍的一个明显弊病就是内容宽泛而空洞.很多书籍长篇大论,恨不得囊括所有最新的技术,但连一个最基本的技术细节也无法解释清楚.有些书籍给读者展现的是网络上随处可见的 ...

  3. Linux 高性能服务器编程——多线程编程

    问题聚焦:     在简单地介绍线程的基本知识之后,主要讨论三个方面的内容:     1 创建线程和结束线程:     2 读取和设置线程属性:     3 线程同步方式:POSIX信号量,互斥锁和条 ...

  4. 《Linux高性能服务器编程》学习笔记

    <Linux高性能服务器编程>学习笔记 Linux高性能服务器编程 TCP/IP协议族 TCP/IP协议族体系结构以及主要协议 数据链路层 网络层 传输层 应用层 封装 分用 测试网络 A ...

  5. 【Todo】【读书笔记】Linux高性能服务器编程

    在读 /Users/baidu/Documents/Data/Interview/服务器-检索端/<Linux高性能服务器编程.pdf> 其实之前读过,要面试了,需要温习. P260 So ...

  6. linux高性能服务器编程第八章(高性能服务器程序框架)

    C/S模型 传统C/S,一端作为客户端,一端作为服务器,这里不做多介绍. P2P模型 peer 2 peer ,每台机器使用服务的同时也提供服务,通俗的讲,没有绝对客户端和服务端的概念,当下云计算的模 ...

  7. linux高性能服务器编程书本总结

    目录 目录分析 第一篇从 1-4章节主要是介绍 计算机网络基础知识和 TCP/IP模型 第二篇 核心篇 5 章到 15 章节 5-6章节 主要介绍 套接字编程API的使用和介绍 7章 是linux 服 ...

  8. 高性能服务器存储服务器,高性能存储服务器

    高性能存储服务器 内容精选 换一换 云硬盘(Elastic Volume Service, EVS)可以为云服务器提供高可靠.高性能.规格丰富并且可弹性扩展的块存储服务,可满足不同场景的业务需求,适用 ...

  9. Linux高性能服务器编程 第5章 Linux网络编程基础API

    5.1 socket 地址 API 现代CPU的累加器一次都能装载(至少)4 字节(这里考虑32位机,下同),即一个整 数.那么这4 字节在内存中排列的顺序将影响它被累加器装载成的整数的值.这就是字节 ...

  10. Linux高性能服务器编程:进程池和线程池原理及应用(有图有代码有真相!!!)

    一.问题引入 在前面编写多进程.多线程服务器时通过动态创建子进程和子线程来实现并发服务器,这样做有以下缺点: 1)动态创建进程.线程将会比较耗费时间,将导致较慢的客户响应. 2)动态创建的子进程只为一 ...

最新文章

  1. p2596 书架(Treap)
  2. linux之hexdump命令
  3. Android 获取包名,版本信息及VersionName名称
  4. 华为二层创建vlan_二层交换机不同VLAN实现互通 (华为)
  5. c#发送简单的post、get请求
  6. 反编译 破解crash html editor winform [WinHTMLEditorControl.dll][.NET Win HTML Editor Control]
  7. 关于asp.net页面缓存
  8. plc secs通讯协议_一种SECS/GEM通讯方法与流程
  9. 遗传+粒子群 求解多配送中心车辆调度问题(python)
  10. 苹果分屏软件_苹果iOS14曝光,全是安卓已有的功能!
  11. linux卸载kodi,如何在Ubuntu 18.04上安装Kodi
  12. 内存储器(主存储器)的分类及存储芯片的扩展方式
  13. 一文详细介绍情绪识别常用的数据集
  14. 解决线上问题-定位CPU占用过高
  15. element input限制输入数字
  16. 【历史上的今天】3 月 7 日:首条海底光缆开通;VeriSign 收购 Network Solutions;计算机图形学先驱诞生
  17. 用Multisim仿真对调幅波进行解调
  18. java 汇率换算_已知外汇牌价折算汇率
  19. 基于Springboot框架的登录注册页面
  20. LogicFlow插件-常用内置

热门文章

  1. 【C/C++】BOOST 线程完全攻略 - 基础篇
  2. jbpm的流程变量与任务变量的存取与更新
  3. java音频播放(转)
  4. arcgis server10.2.2发布地图基础服务的具体步骤
  5. ggplot2图集汇总(一)
  6. 如何七周成为数据分析师
  7. 图的最短路径-----------Dijkstra算法详解(TjuOj2870_The Kth City)
  8. genymotion安装
  9. HTML 小练习(休假申请单)
  10. 开始使用Pyhton