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

  • 相关阅读:
    .NET开发人员如何开始使用ML.NET
    微软开源 Try .NET
    在kubernetes 集群内访问k8s API服务
    微软发布ML.NET 1.0
    现代“十二要素应用”与 Kubernetes
    .NET和Docker ,比翼双飞
    .NET Core 时代已经到了,你准备好了吗
    一份.NET 容器化的调查小结
    容器化时代我们应当选择Kubernetes
    机器学习 ML.NET 发布 1.0 RC
  • 原文地址:https://www.cnblogs.com/charlesblc/p/6286685.html
Copyright © 2011-2022 走看看