基于libevent的多线程执行框架

      众所周知,libevent本身是不支持多线程的,因此需要程序员开发来支持多线程。本人最近的一个项目变需要一个基于libevent的多线程的高性能通信框架。

      该框架由部署在一个高性能服务器中,由一个主线程和多个工作线程组成。每个线程都初始化一个event_base,主线程用于监听客户端发送的通信请求,每个工作线程维持一个工作集队列,每当有新的连接请求到来时,通过轮询算法选择一个工作线程,将主线程获得的socket将其封装后放入被选中工作线程的工作集队列中,此外,工作集线程初始化一个无名pipe,该pipe的句柄被工作线程注册到自身的 event_base中,用于主线程通知工作线程读取其工作集队列。

     基于libevent开发并行程序的最大好处是可以基于libevent自身的事件响应机制来实现线程间的同步,比起通过cond和mutex而言,可靠性要大大提高。 

      具体的代码上班后会贴出来。。。。。。。未完,待续。

 

转载于:https://www.cnblogs.com/dyd/archive/2012/04/30/2477337.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值