03-构造可靠数据传输协议
2016-01-26 02:42
369 查看
03-构造可靠数据传输协议
1.0 无差错、无丢包
2.0 数据差错
没有考虑ACK/NAK差错
2.1 ACKNAK差错
client使用sequence number标识segment
存在问题:send0/1乱序后。client会接二连三的乱序
2.2 数据乱序
3.0 丢包
无论server 的ACK延迟到达还是分组丢失,client只要没有在指定时间内收到ACK就重传
滑动窗口
3.0是一个停等协议,耗时;如果将segment按需分组,则:接收方一次性吉奥夫,如果k分组没有ack那么后面的所有的分组都将重新发送ACK;在这种情况下,发送方使用累计确认,只要收到kACK,那么k之前的所有segment就表示已经收到了。
发送方对于k+1的提前到达,会先缓存,如果k到达,则一次性交付;如果k没有达到,则k、k+1都要重传,这也就是接收方要丢弃k后续分组的原因。
发送方维护base和nextseqnum
接收方维护expectedseqnum
相关文章推荐
- 02-topdown
- U3d键值整理
- MONGODB 与sql聚合操作对应图
- grub 启动错误 "file not found"
- Python如何读取指定文件夹下的所有图像
- Python 列表(list)操作
- for语句引起一个死循环而引发的思考!!!
- 夺命雷公狗暂定的课程表
- 创业的一百一十四天
- UVA - 11136 Hoax or what
- Java I/O流详解
- ubuntu常用命令
- LeetCode 238:Product of Array Except Self
- Flyme patchrom项目笔记
- hdu 5506 GT and set(dfs爆搜)
- 笔记——javascript图片库改进版
- Glide加载图片变色问题
- HDU-1071 The area
- lua与游戏测试(二)
- Eclipse配置