网络线程和工作线程

和客户端和机器人通讯使用老的网络的多线程框架。三个半事件从网络发起到工作线程,进入脚本处理后经由工作线程发送。

(实际上网络线程将消息通过nanomsg发送给gameserver,gameserver工作线程脚本lua处理。lua发送通过nanomsg发回给gate的工作线程。gate收到后在通过旧的网络在工作线程直接发送给客户端或者机器人)


为了脚本对应的对象能够快速访问网络,通过id来索引。使用vector高效一些。

不适用对象的依赖是因为引用空间和生存期管理空间不一致,恐怕异常。

比如说脚本保留了socket的引用,但是c++已经删除了。继续直接访问就会crash。

因此是用index通过vector查找来获得socket.还是引擎负责生存期。删除的时候将position缓存,在新的链接过来的时候重新启用id。类似id池。

网络增加和删除链接,管理每个链接对应的索引。因为工作线程需要发送,所以也需要socket,脚本放出id需要快速找到socket使用。

网络管理生存期。网络线程立刻处理自己的消息,并通知工作线程。其中删除工作将在工作线程中进行。多线程之间使用zeromq或者nanomsg通讯,避开lock。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 引言: 一直都是从事客户端的开发工作,最近抽了点时间想了解一下服务器开发的相关知识,一番博客瞎逛之后,发现了一个不...
    linshuhe1阅读 10,708评论 0 10
  • 从三月份找实习到现在,面了一些公司,挂了不少,但最终还是拿到小米、百度、阿里、京东、新浪、CVTE、乐视家的研发岗...
    时芥蓝阅读 42,466评论 11 349
  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 31,955评论 18 399
  • 不知不觉共修《传习录》快过半了,在先生圣贤教育的熏陶和同修们的扶持互助下,到底算坚持了一半了。与圣贤和经典常伴,最...
    镶润_读书阅读 1,209评论 0 2
  • Muhammad96阅读 1,800评论 4 0