写了一个 reactor 模式多线程网络库 - V2EX
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
whatTheGhost
V2EX    C

写了一个 reactor 模式多线程网络库

  •  
  •   whatTheGhost 2017-02-18 10:26:55 +08:00 2709 次点击
    这是一个创建于 3158 天前的主题,其中的信息可能已经有所发展或是发生改变。
    https://github.com/whatsGhost/agilNet

    之前通读一遍 muduo 源码,萌生自己写一个网络库的想法。春节时间闭关,假期后每天晚上陆陆续续提交。
    目前完成 reactor 模式事件循环分发, TCP 相关操作封装,线程池分配机制,和定时器列队。现在正在加入 http 支持。
    12 条回复    2017-02-20 21:35:38 +08:00
    whatTheGhost
        1
    whatTheGhost  
    OP
       2017-02-18 10:36:41 +08:00
    2 楼,坐标杭州,两年半工作经验,求一个 C++方向的坑。个人技能树 c++,Qt,Boost,SQLserver,mongDB,Linux,design pattern ……

    微信 hebcyeah 邮箱 [email protected]
    htfy96
        2
    htfy96  
       2017-02-18 12:15:12 +08:00 via Android
    是 oschina 上之前那个用了 REUSEPORT 的那个吗?之前看了感觉不错,自己最近也打算跟着写一个
    whatTheGhost
        3
    whatTheGhost  
    OP
       2017-02-18 12:40:45 +08:00
    @htfy96 之前只在 chinaunix 发过,也没用 reuseport 。这个是基于 linux 的 IO 复用机制和基本的 socket 操作实现的。
    最近打算写一个非常通俗详细的文档,大概是从零开始搭一个 reactor 模式网络库。希望给别人学习网络编程有点帮助。
    Charles0429
        4
    Charles0429  
       2017-02-18 13:17:35 +08:00
    @whatTheGhost 楼主看看是否有兴趣 t/338361 ,可以发简历到 [email protected]
    whatTheGhost
        5
    whatTheGhost  
    OP
       2017-02-18 14:18:32 +08:00
    @Charles0429 感谢了。看了一下,感觉和我的技能重合度低,我也不太了解数据库的底层实现,机会不是很大。谢谢了。
    ji4ozhu
        6
    ji4ozhu  
       2017-02-18 17:40:55 +08:00
    海口来么
    SlipStupig
       
    SlipStupig  
       2017-02-19 11:12:04 +08:00
    @ji4ozhu 遇见传说中的大神....
    ji4ozhu
        8
    ji4ozhu  
       2017-02-19 13:23:35 +08:00
    @SlipStupig 不是大神是菜鸟。。
    snnn
        9
    snnn  
       2017-02-20 10:08:00 +08:00 via Android
    你是每个线程都有一个 event loop?
    whatTheGhost
        10
    whatTheGhost  
    OP
       2017-02-20 11:10:23 +08:00 via Android
    @snnn 是的,主 EventLoop 负责监听新连接,其他线程的 EventLoop 负责每个终端连接的读写事件,每个 EventLoop 监听多个终端。(在不开线程池情况下,默认只用一个主 EventLoop 来监听所有 IO 事件)
    snnn
        11
    snnn  
       2017-02-20 19:53:15 +08:00 via Android
    @whatTheGhost 你这做法从哪学来的?很新颖啊!
    whatTheGhost
        12
    whatTheGhost  
    OP
       2017-02-20 21:35:38 +08:00
    @snnn 我看 boost.asio 那本书上的例子是不同的线程 同一个 io_service 调度器。这样效率也很高,不同的线程同时回调事件,但是我觉得这样有线程安全性问题,同一个终端连接数据会被不同的线程访问(所以给那本书打了三星~)。在 boost.asio 库源码有个 example 例子实现了 io_service_pool ,就是一个线程对应一个 io_service 。还有陈硕的 muduo 也是这种机制。
    关于     帮助文档     自助推广系统     博客     API     FAQ     Solana     2718 人在线   最高记录 6679       Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 25ms UTC 07:45 PVG 15:45 LAX 00:45 JFK 03:45
    Do have faith in what you're doing.
    ubao snddm index pchome yahoo rakuten mypaper meadowduck bidyahoo youbao zxmzxm asda bnvcg cvbfg dfscv mmhjk xxddc yybgb zznbn ccubao uaitu acv GXCV ET GDG YH FG BCVB FJFH CBRE CBC GDG ET54 WRWR RWER WREW WRWER RWER SDG EW SF DSFSF fbbs ubao fhd dfg ewr dg df ewwr ewwr et ruyut utut dfg fgd gdfgt etg dfgt dfgd ert4 gd fgg wr 235 wer3 we vsdf sdf gdf ert xcv sdf rwer hfd dfg cvb rwf afb dfh jgh bmn lgh rty gfds cxv xcv xcs vdas fdf fgd cv sdf tert sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf shasha9178 shasha9178 shasha9178 shasha9178 shasha9178 liflif2 liflif2 liflif2 liflif2 liflif2 liblib3 liblib3 liblib3 liblib3 liblib3 zhazha444 zhazha444 zhazha444 zhazha444 zhazha444 dende5 dende denden denden2 denden21 fenfen9 fenf619 fen619 fenfe9 fe619 sdf sdf sdf sdf sdf zhazh90 zhazh0 zhaa50 zha90 zh590 zho zhoz zhozh zhozho zhozho2 lislis lls95 lili95 lils5 liss9 sdf0ty987 sdft876 sdft9876 sdf09876 sd0t9876 sdf0ty98 sdf0976 sdf0ty986 sdf0ty96 sdf0t76 sdf0876 df0ty98 sf0t876 sd0ty76 sdy76 sdf76 sdf0t76 sdf0ty9 sdf0ty98 sdf0ty987 sdf0ty98 sdf6676 sdf876 sd876 sd876 sdf6 sdf6 sdf9876 sdf0t sdf06 sdf0ty9776 sdf0ty9776 sdf0ty76 sdf8876 sdf0t sd6 sdf06 s688876 sd688 sdf86