libevent总结学习

Memcached用了libevent,但是Redis没有用libevent。Redis的代码还没有libevent的三分之一。

libevent有下面几大部分组成:

* 事件管理包括各种IO(socket)、定时器、信号等事件,也是libevent应用最广的模块;

* 缓存管理是指evbuffer功能;

* DNS是libevent提供的一个异步DNS查询功能;

* HTTP是libevent的一个轻量级http实现,包括服务器和客户端

evbuffer和bufferevent的关系:

一言以蔽之,bufferevent使用了evbuffer,并且使用了两份,读入buffer和写出buffer。另外bufferevent里面还加了event。

说明bufferevent是一个带有缓冲区的I/O。也就是说,这个bufferevent知识多了两个evbuffer,然后对event_set函数和event_add函数进行再次封装!

http://blog.csdn.net/chenycbbc0101/article/details/52091085

通过我的这篇文章:

http://www.cnblogs.com/charlesblc/p/5456128.html

可以看出bufferevent主要函数是:

bufferevent *bev = bufferevent_socket_new(base, fd, BEV_OPT_CLOSE_ON_FREE);

    bufferevent_setcb(bev, socket_read_cb, NULL, socket_event_cb, NULL);
    bufferevent_enable(bev, EV_READ | EV_PERSIST);

然后读和写是这样的:

size_t len = bufferevent_read(bev, msg, sizeof(msg) - 1);

bufferevent_write(bev, reply, strlen(reply));

缓冲模块主要用于缓冲从网络接收到的数据,以及
用户提交的数据(用于发送)。很多时候,我们还需要将网络模块层(非TCP层)的这些缓冲数据拷贝到用户层,而这些内存拷贝
都会消耗时间。

原文地址:https://www.cnblogs.com/charlesblc/p/6286685.html