基于libevent的多线程执行框架
摘要:
众所周知,libevent本身是不支持多线程的,因此需要程序员开发来支持多线程。本人最近的一个项目变需要一个基于libevent的多线程的高性能通信框架。 该框架由部署在一个高性能服务器中,由一个主线程和多个工作线程组成。每个线程都初始化一个event_base,主线程用于监听客户端发送的通信请求,每个工作线程维持一个工作集队列,每当有新的连接请求到来时,通过轮询算法选择一个工作线程,将主线程获得的socket将其封装后放入被选中工作线程的工作集队列中,此外,工作集线程初始化一个无名pipe,该pipe的句柄被工作线程注册到自身的event_base中,用于主线程通知工作线程读取其工... 阅读全文
posted @ 2012-04-30 22:42 卡西欧 阅读(1444) 评论(3) 推荐(0)
浙公网安备 33010602011771号