Libevent基础

来源:互联网 发布:win10重置网络cmd命令 编辑:程序博客网 时间:2024/04/30 04:35

一,初识Libevent

1,libevent简介

        libevent是一个基于事件触发的网络库,适用于windows、linux、bsd等多种平台,内部使用select、epoll、kqueue等系统调用管理事件机制。

       libevent更是一个轻量级的开源的高性能的网络库,被众多的开源项目使用,例如大名鼎鼎的memcached等。

       官网:http://libevent.org/

2,Libevent功能

       Libevent提供了事件通知,io缓存事件,定时器,超时,异步解析dns,事件驱动的http server以及一个rpc框架。

       事件通知:当文件描述符可读可写时将执行回调函数。

       Io缓存:缓存事件提供了输入输出缓存,能自动的读入和写入,用户不必直接操作io。

       定时器:libevent提供了定时器的机制,能够在一定的时间间隔之后调用回调函数。

       异步的dns解析:libevent提供了异步解析dns服务器的dns解析函数集。

       事件驱动的http服务器:libevent提供了一个简单的,可集成到应用程序中的HTTP服务器。

       RPC客户端服务器框架:libevent为创建RPC服务器和客户端创建了一个RPC框架,能自动的封装和解封数据结构。

3,Libevent特点

  • 事件驱动,高性能;

  • 轻量级,专注于网络,不如ACE那么臃肿庞大,只提供了简单的网络API的封装,线程池,内存池,递归锁等均需要自己实现

  • 开放源码,代码相当精炼、易读;

  • 跨平台,支持Windows、Linux、BSD和Mac OS;

  • 支持多种I/O多路复用技术epoll、poll、dev/poll、select和kqueue等),在不同的操作系统下,做了多路复用模型的抽象,可以选择使用不同的模型,通过事件函数提供服务

  • 支持I/O,定时器和信号等事件;

  • 采用Reactor模式;

4,Reactor模式

      Reactor释义“反应堆”,是一种事件驱动机制。和普通函数调用的不同之处在于:应用程序不是主动的调用某个API完成处理,而是恰恰相反,Reactor逆置了事件处理流程,应用程序需要提供相应的接口并注册到Reactor上,如果相应的时间发生,Reactor将主动调用应用程序注册的接口,这些接口又称为“回调函数”。使用Libevent也是想Libevent框架注册相应的事件和回调函数;当这些时间发声时,Libevent会调用这些回调函数处理相应的事件(I/O读写、定时和信号)。
    用“好莱坞原则”来形容Reactor再合适不过了:不要打电话给我们,我们会打电话通知你。 

    具体参见:

                I/O并发模式:Reactor模式与Proactor模式

               http://blog.csdn.net/success041000/article/details/6725110

二、源码组织结构


    Libevent的源代码虽然都在一层文件夹下面,但是其代码分类还是相当清晰的,主要可分为头文件、内部使用的头文件、辅助功能函数、日志、libevent框架、对系统I/O多路复用机制的封装、信号管理、定时事件管理、缓冲区管理、基本数据结构和基于libevent的两个实用库等几个部分,有些部分可能就是一个源文件。

1)头文件

主要就是event.h:事件宏定义、接口函数声明,主要结构体event的声明;

2)内部头文件

xxx-internal.h:内部数据结构和函数,对外不可见,以达到信息隐藏的目的;

3)libevent框架

event.c:event整体框架的代码实现;

4)对系统I/O多路复用机制的封装

epoll.c:对epoll的封装;

select.c:对select的封装;

devpoll.c:对dev/poll的封装;

kqueue.c:对kqueue的封装;

5)定时事件管理

min-heap.h:其实就是一个以时间作为key的小根堆结构;

6)信号管理

signal.c:对信号事件的处理;

7)辅助功能函数

evutil.h 和evutil.c:一些辅助功能函数,包括创建socket pair和一些时间操作函数:加、减和比较等。

8)日志

log.h和log.c:log日志函数

9)缓冲区管理

evbuffer.c和buffer.c:libevent对缓冲区的封装;

10)基本数据结构

compat/sys下的两个源文件:queue.h是libevent基本数据结构的实现,包括链表,双向链表,队列等;_libevent_time.h:一些用于时间操作的结构体定义、函数和宏定义;

11)实用网络库

http和evdns:是基于libevent实现的http服务器和异步dns查询库;

三,Libevent安装与编译
官网:http://libevent.org/ 下载libevent2.0.12-stable后
shenhuayu@shenhuayu-VirtualBox ~$ tar -zxvf libevent-2.0.21-stable.tar.gz
shenhuayu@shenhuayu-VirtualBox ~$ cd libevent
shenhuayu@shenhuayu-VirtualBox ~/libevent-2.0.21-stable $ ./configure
shenhuayu@shenhuayu-VirtualBox ~/libevent-2.0.21-stable $ make
shenhuayu@shenhuayu-VirtualBox ~/libevent-2.0.21-stable $ sudo make install


如果源文件为main.c,则这样进行编译

gcc main.c -g -o mymain -levent




0 0
原创粉丝点击