计算机网络重要机制(一)可靠数据传输

操作系统,计算机网络都属于计算机系统,为了使得整个系统运行起来,人们根据当时的硬件条件和理论认识设计了各种的算法(也可以叫机制),这些机制有些被抛弃,有些被进化。所以操作系统、计算机网络里面的内容概括起来就是:条件(已知)、问题(未知)----》算法----》实现;在具体实现的时候为了配合算法设计了各种精巧的数据结构。《计算机网络重要机制》系列总结的是自己学习计算机网络中的重要机制,材料主要参考《计算机网络自顶向下》和网上资料,叙述方式就是上面的框架。


1,传输的基本流程图如下所示:


图1

2,下面要解决传输中两个问题:丢包、坏包(01bit发生翻转),要使用到的工具是数学中的有限状态机如下图:


图2

3,假设说网络层的传输是没有问题的,如图1b图,那应该怎样设计我们的传输层协议呢?如下图:


图3


4,假设网络层中传输过程中存在包被破坏(01翻转)且接收方还能收到这个坏包,那么上面的1.0协议该如何改进呢,如下图:


图4



5,上面的rdt2.0没有考虑NAK/ACK包在传输中被破坏且还能被发送方接受到的问题,未解决这个问题为每个数据包增加了1bit位的序列号,即0或1,rdt2.1如下图:因为增加了两个序列号,所以rdt2.1的状态是2.0状态的二倍,此时从图上已经感觉到略显复杂,其实并不复杂,就是把2.0版本重复一次而已(但并不完全一样),还有这个图是可以简化的。


图5


图6

6,观察图6知道,receiver在收到坏包时,会向sender发送NAK,receiver收到上一个包(重复包)时,会向sender发送ACK,但是目的都是一样,需要sender送正确的当前包,所以这两个情况可以合并起来考虑,那怎么合并呢,其实很简单,就是出现上面两种情况时,都发送上一个包的ACK(此时的ACK也带有序列号01了),这样sender也稍微调整一下就可以了。如rdt2.2下图:


图7


图8

jj














本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/420969.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

命名空间和作用域

一,namespace namespace是名字到对象的映射,python里面的大部分命名空间由字典实现。如果有性能问题,会更改。 命名空间的举例 •存放内置函数的集合(abs()这种函数,和内建的异常) •模块中的全局名称 •函…

python类

一,类 1,类是摸板,里面有组合数据,实现功能的方法。 2,类里面有可以改变自身的方法__init__函数 3,类和模块类似,运行时创建,创建后修改 4,类成员通常是public&#xff…

Web Form要“jquery”ScriptResourceMapping。请添加一个名为 jquery (区分大小写)的 ScriptResourceMapping。”的解决办法。...

1.先将aspnet.scriptmanager.jquery.dl 复制到bin (网站根目录下的bin文件夹找不到,看看下面的图片中点击[显示所有文档]) 文件夹下。 2.在网站根目录下scripts文件夹,向里边添加jquery-1.7.2.min.js和jquery-1.7.2.js(可根据自己需要使用不同的版本)…

python继承多重继承

一,基本语法 class MyClass(BaseClass):def __init__(self):print(...)class MyDefineClass(object):def __init__(self):print(继承自object类)MyDefineClass.__init__(None) # 属性访问 me MyDefineClass() # 实例对象 继承自object类 继承自object类 二&#x…

Windows XP系统安装SQL Server 2005(开发版)图解

转自Windows XP系统安装SQL Server 2005(开发版)图解 安装前提:由于有些从网上的下载的项目需要导入SQL Server 2005的数据文件,因此,今天便安装了这个数据库,我的系统中已经安装了SQL Server2000所以是在它之上安装SQL Server2005的。 一、数…

用turtle画各种各样的数学图形

ps,用turtle导入小海龟来画图。画图代码都要导入海龟库哦,见下面第一行。 import turtle as t直线 # 画直线 def draw_line():pen t.Pen()pen.fd(200) # 直线默认水平方向 draw_line() 画正方形 def draw_square():pen t.Pen()for i in range(4): …

实验3 系统调用

系统调用 实验目的 建立对系统调用接口的深入认识掌握系统调用的基本过程能完成系统调用的全面控制为后续实验做准备 实验内容 此次实验的基本内容是:在Linux 0.11上添加两个系统调用,并编写两个简单的应用程序测试它们。 iam() 第一个系统调用是iam()&a…

python标准库(一)

操作系统接口os 切换目录 >>> import os>>> os.getcwd() # 得到当前工作目录C:\\Users>>> os.chdir(F:\\) # 切换工作目录到F盘>>> os.system(mkdir tody) # 在f盘创建一个叫tody的文件夹0import os 与 from os import * ,要…

python标准库(二)

格式化输出 reprlib 库用来格式化 >>> import reprlib >>> reprlib.repr(set(aabbccddeeeff)) "{a, b, c, d, e, f}" >>>对集合能排序 >>> reprlib.repr(set(fdajfejaa)) "{a, d, e, f, j}" >>>pprint库用…

实验4 进程运行轨迹的跟踪与统计

进程运行轨迹的跟踪与统计 难度系数:★★★☆☆ 实验目的 掌握Linux下的多进程编程技术;通过对进程运行轨迹的跟踪来形象化进程的概念;在进程运行轨迹跟踪的基础上进行相应的数据统计,从而能对进程调度算法进行实际的量化评价&…

虚拟环境创建,pip管理包

windows10虚拟环境的创建,pip管理包1.虚拟环境的创建1.1 为什么要创建虚拟环境1.2 创建虚拟环境1.3 激活虚拟环境1.3.1 激活方式1.3.2 检查是否创建成功2.用pip管理包2.1 pip的基本使用2.2 pip创建安装的文件requirements.txt2.3 安装包对应的版本2.4 用pip - r ins…

vi文字处理器

http://blog.csdn.net/wangloveall/article/details/22649331 摘要:vi是类UNIX命令行接口的标准文字处理软件,也是进行shell脚本程序编写与服务器设置的非常重要的工具。本文介绍vi文字处理器,包括vi简介、vi怎么使用、vi的加强版vim。 关键词…

用numpy,matplotlib库画笛卡尔爱心曲线

1650年,斯德哥尔摩的街头,52岁的笛卡尔邂逅了18岁的瑞典公主克里斯汀。   那时,落魄、一文不名的笛卡尔过着乞讨的生活,全部的财产只有身上穿的破破烂烂的衣服和随身所带的几本数学书籍。生性清高的笛卡尔从来不开口请求路人施舍…

centos7虚拟机共享本机磁盘的方法

说明:这个方法不一定是通用的,也可能不是最快捷的,但是感觉比较稳妥的办法。 1,首先坚持两个进程是否启动:右击:我的电脑-管理-服务,检查server服务和Workstation服务是否启动。如果没有启动&a…

服务器小程序servlet的使用

servlet的创建使用一,三种创建方式1.1 实现servlet接口1.2 继承GenericServlet1.3 继承HttpServlet二,servlet使用2.1 web.xml文件的配置2.1.1 创建xml文件2.1.2 手写web.xml文件2.2 在8080端口下访问2.2.1 servlet的生命周期servlet是服务器小程序。是个…

el表达式,c标签的使用

el表达式的使用 学生类 public class Student {int id;String name;String sex;String birth;public Student() {}public Student(int id, String name, String sex, String birth) {super();this.id id;this.name name;this.sex sex;this.birth birth;}// el 表达式取实…

conda虚拟环境中安装ipython

问题:今天安装了tensorflow,启动ipython竟然提示如下: In [1]: import tensorflow as tf --------------------------------------------------------------------------- ModuleNotFoundError Traceback (most recen…