博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Socket编程注意接收缓冲区大小
阅读量:6188 次
发布时间:2019-06-21

本文共 894 字,大约阅读时间需要 2 分钟。

转自:http://www.cnblogs.com/ITBread/p/3900254.html

 

最近在做一个udp升级程序,因文件有点大,需要将程序分成多个包发送,每次发送一个包,收到回复后发送下一个包,直到完成,这样就控制为顺序发送,保证了完整性,简单定义一个协议,每个包,包含包编号,当前数据长度等信息

包头 命令 子命令 总包数 包编号 总长度 当前包长度 校验信息 数据
6byte 1 1 1 1 4 4 2 0-1024

命令:290

子命令:发送开始为 1   发送数据为2  发送成功为3(接收端发送给发送端)  发送失败为4

总包数: 文件分成多少个包

包编号:当前发送的是第几包(索引从0开始)

总长度:文件长度

当前包长度:当前包的数据长度(《=1024)每次发送1024,最后一包可能少于1024

校验信息:用计算是否丢包用,可以用crc算法 ,这里为了简单设置为0

升级程序流程如下:

1、发送开始命令(发送端--》接收端)

2、传输数据(发送端收到接收端的第一个回复后,然后发送第一个数据包,收到第2个回复,然后发送的第3个包,如此循环,直到发送完成)

3、传输数据完成(接收端,收到所有包后,发送成功命令给发送端)

以上是处理思路,写好代码之后,测试ok,因设备太多 上1000台,一个一个人工处理,太麻烦,想批量升级,修改代码后,可以使用,一次最多5台,多了就会出现部分设备发送到一部分时就不成功。仔细检查处理流程,并没有发现任何错误,最后请同事帮忙看代码,分析也没有发现错误,抓包(Wireshark)分析后,有收到回复包,也有发送数据,但就是中断了,仔细分析后,猜测是接收缓冲区小(默认8192字节),设置接收缓冲区为32k字节后,再试,可以一次升级20多台。

查找相关资料后,是由于udp接收数据大于缓冲区时就会把数据丢掉。

分析原因:一个数据包1k多,5台接近8192,这就是为什么5台时,很顺利。

同理设置接收缓冲区为32k后,就可以升级20多了。

转载于:https://www.cnblogs.com/x_wukong/p/5761676.html

你可能感兴趣的文章
为阿里云增加数据盘(LVM管理)
查看>>
整数划分问题
查看>>
用Apache Spark进行大数据处理——第一部分:入门介绍
查看>>
XenServer需要配置多少网卡
查看>>
ipod无法使用无线网络问题分析
查看>>
Vert.x 提供web API 译<八>
查看>>
gcc 降低版本
查看>>
YII Framework学习教程-YII的Modules(模块化)
查看>>
iOS: 在iPhone和Apple Watch之间共享数据 App Groups
查看>>
Zabbix应用之Server/Agent部署
查看>>
添加PaloAlto 8.0到EVE-NG
查看>>
开源大数据处理工具汇总(上)
查看>>
lduan server 2012 IIS 远程管理(二十六)
查看>>
kube-shell安装与使用
查看>>
Python基础学习(三)
查看>>
centos7 下yum安装mysql8.0.15
查看>>
关于AsyncTask异步执行任务Demo
查看>>
2015年8月30日课程作业(练习)
查看>>
callable() 函数
查看>>
有4个线程A、B、C、D,分别打印1、2、3、4,请同时启动他们,但是要求按照1234的顺序输出结果...
查看>>