社区
李宁的课程社区_NO_3
《Java基础篇-从入门到精通》
帖子详情
线程连接
蒙娜丽宁
企业官方账号
领域专家: 后端开发技术领域
2023-01-13 10:47:57
课时名称
课时知识点
线程连接
...全文
132
回复
打赏
收藏
线程连接
课时名称课时知识点线程连接
复制链接
扫一扫
分享
转发到动态
举报
写回复
配置赞助广告
用AI写文章
回复
切换为时间正序
请发表友善的回复…
发表回复
打赏红包
libevent多
线程
libevent多
线程
, 参考mariotcp 参考http://blog.csdn.net/i_am_jojo/article/details/7587838流程图
Android多
线程
文件夹下载及断点续传
Android实现网络多
线程
下载,断点续传,压缩包内有两个项目: downloadDemo:多
线程
下载 MulThreadDownloader:断点续传(网上别人的项目)
Android多
线程
断点续传下载+在线播放音乐
Android多
线程
断点续传下载+在线播放音乐,我想很多小白都想要。
多
线程
编程技术开发资料.pdf
多
线程
编程技术开发资料.pdf
代码客:G-Socket(IOCP) 1.0 (Server/Client)例程源码+Server体验程序+强大的压力测试工具
结构层次及相互联系 (1)、工作
线程
:响应
连接
的IO投递返回并负责投递读请求,并将IO返回结果投递给处理
线程
,可设定参数决定工作
线程
数量; (2)、处理
线程
:处理
线程
调用回调函数将信息传递给应用层或协议栈,可设定参数决定工作处理数量; (3)、看守
线程
:响应Accept事件调用AcceptEx,检测
连接
和心跳超时 ,将信息投递给工作
线程
,模块仅有一个看守
线程
。 1. 技术要求 (1)、
线程
同步:Lock指令、临界段; (2)、主要Socket API:WSASend、WSARecv、AcceptEx、DisconnectEx; (3)、内存管理:
连接
池(句柄重用)、内存池; (4)、数据0拷贝:通过内置处理
线程
,上层应用可以避免自建
线程
池及复制数据的过程。同时提供GBuf内存分配功能,应用层获得分配地址及填充数据之后亦可直接投递给内核/驱动层; (5)、数据顺序同步:同一个
连接
同时只有一个处理
线程
响应其IO事件; (6)、IO请求投递:单投递读、多投递写; (7)、0缓冲读投递:可条件编译实现,以适用大规模
连接
要求。 (8)、超时机制:可设置空
连接
(
连接
不发送数据)超时时间以防止DOS攻击,也可设置心跳超时时间防止网络故障导致的现有
连接
成为虚
连接
避免耗尽系统资源。 (9)、接口技术:API、回调函数、客户句柄(客户
连接
句柄)。 (10)、主、被动发送:不使用HASH、MAP及LIST技术,即可提供安全可靠高效的客户
连接
句柄,以实现服务器端主被动发送数据功能; (11)、PerHandleData的回收不以IO投递的计数器或链表来做依据但仍能安全回收,同时尽量避免在高频的读写操作时做其他无关的操作以提高读写效率。 (12)、处理
线程
和工作
线程
有着良好分工界限,繁重的工作交给处理
线程
完成,工作
线程
工作量最大限度的减少,仅响应投递返回及读投递的操作; (13)、支持AWE,模块自动识别AWE是否开启(需手动开启),“否”则使用虚拟内存机制。 2. 功能要求 (1)、多IP多端口监听,每个监听可设置不同的回调函数,以高效的区别处理数据 (2)、可设置每秒最大的
连接
并发量和空
连接
(
连接
不发数据)超时时间以防止DOS攻击造成的服务瘫痪、具有心跳处理(防网络异常造成的虚
连接
)功能 (3)、不加协议的透明传输,可适用广泛的网络通讯环境 (4)、可现实主、被动发送数据,但不会因兼顾主动发送而额外增加降低效率的工作 (5)、内置处理
线程
,上层应用可不必自建
线程
池处理数据,所有IO事件按顺序调用回调函数并可以在回调函数内直接处理数据,不必担心多
线程
造成的接收数据乱序的问题。 (6)、高效率的数据对应关联机制,在初次
连接
并根据登录数据设置每个
连接
对应的宿主(Owner)之后,再接收的数据即可立即获得该
连接
对应的宿主,而不必再做额外的查询工作,并且模块内部采用的是指针关联方式,对于长
连接
、主动发送的服务器系统而言是高效率的。 (7)、可兼容IPv6 3. 注意事项 因硬件环境和应用环境不同,不合理的配置会出现效率及性能上的问题,因此以下情况出现时,请务必与作者联系以确保获得更好的参数配置: (1)、
连接
量超过1000个的。超过的应结合具体硬件配置和网络带宽等因素综合设定运行参数。 (2)、带宽使用率超过20%的。工作
线程
和处理
线程
数量的设置也是综合考虑数据吞吐量和数据处理负载的因素来设置的,过多的
线程
会在调度上浪费时间,同时也应该综合考虑
线程
优先级别来设置工作
线程
和处理
线程
数量,两者的设置也不一定能相等。 (3)、服务器端有主动发送需求的、短
连接
(含网络故障造成的
连接
断开)出现频率高的。 压力测试工具介绍: 一、 使用G-TcpClient模块 二、 可以设定间隔时间发起大规模长、短
连接
三、 可以发起密集数据包,包括即时和定时发送,1M的光纤带宽最大可以达到100K/S(单向)以上,100M本地网最大可以达到10M/S(单向)以上 四、 数据发送仅由一个独立
线程
但当,每点击一次Connect就创建一个
线程
根据当前参数发起
连接
。 五、 测试前提:服务器接收客户端数据后立即原样返回给客户端
李宁的课程社区_NO_3
2
社区成员
832
社区内容
发帖
与我相关
我的任务
李宁的课程社区_NO_3
更多精彩内容请关注微信公众号:「极客起源」,UnityMarvel创始人,企业内训讲师、IT畅销书作者,CSDN学院讲师,拥有多年软件开发经验和培训经验。主要著作包括《鸿蒙征途:App开发实战》、《Python从菜鸟到高手》、《Python爬虫技术:深入理解原理、技术与开发》,培训企业学员数千人。制作在线课程数千小时。更多视频课程,请访问我的B站:https://space.bilibili.com/477001733
复制链接
扫一扫
分享
社区描述
更多精彩内容请关注微信公众号:「极客起源」,UnityMarvel创始人,企业内训讲师、IT畅销书作者,CSDN学院讲师,拥有多年软件开发经验和培训经验。主要著作包括《鸿蒙征途:App开发实战》、《Python从菜鸟到高手》、《Python爬虫技术:深入理解原理、技术与开发》,培训企业学员数千人。制作在线课程数千小时。更多视频课程,请访问我的B站:https://space.bilibili.com/477001733
社区管理员
加入社区
获取链接或二维码
近7日
近30日
至今
加载中
查看更多榜单
社区公告
暂无公告
试试用AI创作助手写篇文章吧
+ 用AI写文章