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层)的这些缓冲数据拷贝到用户层,而这些内存拷贝
都会消耗时间。