Mangos源码分析(10):服务器公共组件实现之发包的方式
来源:互联网 发布:数组长度是什么 编辑:程序博客网 时间:2024/05/18 03:42
前面一直都在说接收数据时的处理方法,我们应该用专门的IO线程,接收到完整的消息包后加入到主线程的消息队列,但是主线程如何发送数据还没有探讨过。
一般来说最直接的方法就是逻辑线程什么时候想发数据了就直接调用相关的socket API发送,这要求服务器的玩家对象中保存其连接的socket句柄。但是直接send调用有时候有会存在一些问题,比如遇到系统的发送缓冲区满而阻塞住的情况,或者只发送了一部分数据的情况也时有发生。我们可以将要发送的数据先缓存一下,这样遇到未发送完的,在逻辑线程的下一次处理时可以接着再发送。
考虑数据缓存的话,那这里这可以有两种实现方式了,一是为每个玩家准备一个缓冲区,另外就是只有一个全局的缓冲区,要发送的数据加入到全局缓冲区的时候同时要指明这个数据是发到哪个socket的。如果使用全局缓冲区的话,那我们可以再进一步,使用一个独立的线程来处理数据发送,类似于逻辑线程对数据的处理方式,这个独立发送线程也维护一个消息队列,逻辑线程要发数据时也只是把数据加入到这个队列中,发送线程循环取包来执行send调用,这时的阻塞也就不会对逻辑线程有任何影响了。
采用第二种方式还可以附带一个优化方案。一般对于广播消息而言,发送给周围玩家的数据都是完全相同的,我们如果采用给每个玩家一个缓冲队列的方式,这个数据包将需要拷贝多份,而采用一个全局发送队列时,我们只需要把这个消息入队一次,同时指明该消息包是要发送给哪些socket的即可。有关该优化的说明在云风描述其连接服务器实现的blog文章中也有讲到,有兴趣的可以去阅读一下。
一般来说最直接的方法就是逻辑线程什么时候想发数据了就直接调用相关的socket API发送,这要求服务器的玩家对象中保存其连接的socket句柄。但是直接send调用有时候有会存在一些问题,比如遇到系统的发送缓冲区满而阻塞住的情况,或者只发送了一部分数据的情况也时有发生。我们可以将要发送的数据先缓存一下,这样遇到未发送完的,在逻辑线程的下一次处理时可以接着再发送。
考虑数据缓存的话,那这里这可以有两种实现方式了,一是为每个玩家准备一个缓冲区,另外就是只有一个全局的缓冲区,要发送的数据加入到全局缓冲区的时候同时要指明这个数据是发到哪个socket的。如果使用全局缓冲区的话,那我们可以再进一步,使用一个独立的线程来处理数据发送,类似于逻辑线程对数据的处理方式,这个独立发送线程也维护一个消息队列,逻辑线程要发数据时也只是把数据加入到这个队列中,发送线程循环取包来执行send调用,这时的阻塞也就不会对逻辑线程有任何影响了。
采用第二种方式还可以附带一个优化方案。一般对于广播消息而言,发送给周围玩家的数据都是完全相同的,我们如果采用给每个玩家一个缓冲队列的方式,这个数据包将需要拷贝多份,而采用一个全局发送队列时,我们只需要把这个消息入队一次,同时指明该消息包是要发送给哪些socket的即可。有关该优化的说明在云风描述其连接服务器实现的blog文章中也有讲到,有兴趣的可以去阅读一下。
阅读全文
0 0
- Mangos源码分析(10):服务器公共组件实现之发包的方式
- .Mangos源码分析(10):服务器公共组件实现之发包的方式
- Mangos源码分析(10):服务器公共组件实现之发包的方式
- Mangos源码分析(10):服务器公共组件实现之发包的方式
- 服务器公共组件实现 -- 发包的方式
- 服务器公共组件实现 -- 发包的方式
- Mangos源码分析(7):服务器公共组件实现之游戏主循环
- Mangos源码分析(8):服务器公共组件实现之消息队列
- Mangos源码分析(9):服务器公共组件实现之环形缓冲区
- Mangos源码分析(11):服务器公共组件实现之状态机
- Mangos源码分析(12):服务器公共组件实现之事件与信号
- Mangos源码分析(7):服务器公共组件实现之游戏主循环
- Mangos源码分析(8):服务器公共组件实现之消息队列
- Mangos源码分析(9):服务器公共组件实现之环形缓冲区
- Mangos源码分析(11):服务器公共组件实现之状态机
- Mangos源码分析(12):服务器公共组件实现之事件与信号
- Mangos源码分析(7):服务器公共组件实现之游戏主循环
- Mangos源码分析(8):服务器公共组件实现之消息队列
- 解决error C1083: 无法打开包括文件: “sys/time.h”的问题
- iOS OC与H5网页交互之OC传值给JS(WKWebView)
- 跑马灯效果
- 洛谷 P3371 【模板】单源最短路径(Dijkstra + 堆优化)
- 应对双11挑战,阿里巴巴智能化运维体系演进与建设
- Mangos源码分析(10):服务器公共组件实现之发包的方式
- Encoding.GetEncoding 编码列表
- a 标签href 跳转页面
- Ubuntu下git本地仓库与远程仓库的同步
- Unity Shader 学习笔记(1) DrawCall
- Javascript E-mail验证
- 写入日志到文本文件
- 1004. 成绩排名 (20)——C语言
- ERROR 1503 (HY000): A PRIMARY KEY must include all columns in the table's partitioning function