众所周知,libevent本身是不支持多线程的,因此需要程序员开发来支持多线程。本人最近的一个项目变需要一个基于libevent的多线程的高性能通信框架。
该框架由部署在一个高性能服务器中,由一个主线程和多个工作线程组成。每个线程都初始化一个event_base,主线程用于监听客户端发送的通信请求,每个工作线程维持一个工作集队列,每当有新的连接请求到来时,通过轮询算法选择一个工作线程,将主线程获得的socket将其封装后放入被选中工作线程的工作集队列中,此外,工作集线程初始化一个无名pipe,该pipe的句柄被工作线程注册到自身的 event_base中,用于主线程通知工作线程读取其工作集队列。
基于libevent开发并行程序的最大好处是可以基于libevent自身的事件响应机制来实现线程间的同步,比起通过cond和mutex而言,可靠性要大大提高。
具体的代码上班后会贴出来。。。。。。。未完,待续。