网络数据包在不同网络环境下的丢失表现
2010-09-09 09:09
232 查看
最近项目在网络数据发包和收包的时候出了问题,连接是采用Tcp协议进行的。经过分析问题应该是服务端的发送队列溢出或者是客户端的接收队列溢出造成的数据丢失。详细情况如下。首先客户端在登录到服务端的时候会收到服务端发送过来的大量数据,其中有一类数据为长数据报文,数据量比较大,每个数据包有10000多个字节。而在客户端收到主这些数据之后的数据会有一定的机会丢失。其中我们不清楚是服务端是否成功发送出去,还是客户端在接收时没能够成功放进缓冲区中。这个情况只在Internet中出现,在局域网中未发现有丢失数据现象。所以认为是网络环境触发了这个漏洞。
在TCP/IP的协议下,发送的大数据包会在运输层中的tcp协议被会成许多个tcp包来发送的,然后在接收端的运输层内按顺序进行重组,当接收到完整的数据包时再向应用层发出接收的通知。由于在物理层中数据报文很可能会根据当时的网络环境不同经过不同的路由,所以到达的时间和顺序都不一样。
....未完待续
在TCP/IP的协议下,发送的大数据包会在运输层中的tcp协议被会成许多个tcp包来发送的,然后在接收端的运输层内按顺序进行重组,当接收到完整的数据包时再向应用层发出接收的通知。由于在物理层中数据报文很可能会根据当时的网络环境不同经过不同的路由,所以到达的时间和顺序都不一样。
....未完待续
相关文章推荐
- linux 添加路由,让不同网络环境过来的访问按原线路回去
- iOS中根据网络环境显示不同图片
- [数据恢复答疑]不同的RAID方案都适合于什么环境?
- 【Java/Android性能优 4】PreloadDataCache支持预取的数据缓存,使用简单,支持多种缓存算法,支持不同网络类型,扩展性强
- 数据库表表面上存在索引和防错机制,然而一个简单的查询就会耗费很长时间。Web应用程序或许在开发环境中运行良好,但在产品环境中表现同样糟糕。如果你是个数据库管理员,你很有可能已经在某个阶段遇到上述情况。
- 奇思妙想:通过网络回迁raid丢失后的数据
- Maven配置测试和开发环境连接不同数据库
- Java多线程环境下如何高效安全处理数据(输入输出流、文件、网络等)(一)
- Reachability 网络编程总结(解析数据,下载文件,确认网络环境)
- 封装项目整体架构,访问网络数据,展示列表数据,根据图片数量的不同来多条目加载,使用Universal-Image-Loader进行图片加载
- 两个不同的OS环境,通过中断和共享内存进行数据传输
- 网络-Netty(一)-NIO概念Channel是一个对象,可以通过它读取和写入数据。可以把它看做IO中的流。但是它和流相比还有一些不同:
- IOS应用网络数据包拦截之三 网络环境模拟软件Network Link Conditioner使用介绍
- python中对于“+”符号,不同的数据类型表现的不同的行为
- 阿里云ECS数据盘挂载过程 根据不同环境挂载网站目录
- Recorder︱深度学习小数据集表现、优化(Active Learning)、标注集网络获取
- 根据网络请求数据,给子条目设置背景颜色不同
- Android判断网络状态是否断开+Android完全关闭应用程序+ 本文讲述了Android中不同Activity之间的数据传递 — Bundle对象的实现(-)+Android中Bundle的使用示例
- 无废话Android之smartimageview使用、android多线程下载、显式意图激活另外一个activity,检查网络是否可用定位到网络的位置、隐式意图激活另外一个activity、隐式意图的配置,自定义隐式意图、在不同activity之间数据传递(5)
- Reachability 网络编程总结(解析数据,下载文件,确认网络环境)