• 计算机网络知识整理


    计算机网络知识整理

    五层协议体系结构

    1.1 应用层

          应用层的任务是通过应用进程间的交互来完成特定网络应用。应用层协议定义的是应用进程(进程:主机中正在运行的程序)间的通信和交互的规则。对于不同的网络应用需要不同的应用层协议。在互联网中应用层协议很多,如域名系统DNS,支持万维网应用的HTTP协议,支持电子邮件的SMTP协议等等。我们把应用层交互的数据单元称为报文。

     

    1.2 传输

          传输层的主要任务就是负责向两台主机进程之间的通信提供通用的数据传输服务。应用进程利用该服务传送应用层报文。“通用的”是指并不针对某一个特定的网络应用,而是多种应用可以使用同一个传输层服务。由于一台主机可同时运行多个线程,因此传输层有复用和分用的功能。所谓复用就是指多个应用层进程可同时使用下面传输层的服务,分用和复用相反,是传输层把收到的信息分别交付到上面应用层中的相应进程。

     

    1.2.1 传输层主要使用的协议

          传输控制协议TCP:提供面向连接的,可靠的数据传输服务。

          用户数据协议UDP:提供无连接的,尽最大努力的数据传输服务(不保证数据传输的可靠性)。

     

    1.2.2 UDP的主要特点

          (1)UDP是无连接的;

          (2)UDP使用尽最大努力交付,即不保证可靠交付,因此主机不需要维持复杂的链接状态;

          (3)UDP是面向报文的;

          (4)UDP没有拥塞控制,因此网络出现拥塞不会使源主机的发送速率降低(对实时应用很有用,如IP电话,实时视频会议等);

          (5)UDP支持一对一、一对多、多对一和多对多的交互通信;

          (6)UDP的首部开销小,只有8个字节,比TCP的20个字节的首部要短。

     

    1.2.3 TCP的主要特点

          (1)TCP是面向连接的。(就好像打电话一样,通话前需要先拨号建立连接,通话结束后要挂机释放连接);

          (2)每一条TCP连接只能有两个端点,每一条TCP连接只能是点对点(一对一);

          (3)TCP提供可靠交付的服务。通过TCP连接传送的数据,无差错、不丢失、不重复、并且按序到达;

          (4)TCP提供全双工通信。TCP允许通信双方的应用进程在任何时候都能发送数据。TCP连接的两端都设有发送缓存和接收缓存,用来临时存放双方通信的数据;

          (5)面向字节流。TCP中的“流”指的是流入进程或从进程流出的字节序列。“面向字节流”的含义是:虽然应用程序和TCP的交互是一次一个数据块,但TCP把应用程序交下来的数据仅仅看成是一连串的无结构的字节流。

     

    1.3 网络层

          网络层负责为分组交换网上的不同主机提供通信服务。在发送数据时,网络层把运输层产生的报文段或用户数据报封装成分组和包进行传送。在TCP/IP体系结构中,由于网络层使用IP协议,因此分组也叫IP数据报,简称数据报

          网络层的另一个任务就是选择合适的路由,使源主机运输层所传下来的分组,能通过网络层中的路由器找到目的主机。

          互联网是由大量的异构网络通过路由器相互连接起来的。互联网使用的网络层协议是无连接的网际协议和许多路由选择协议,因此网络层也叫做网际层IP层

     

    1.4 数据链路层

          数据链路层通常简称为链路层。两台主机之间的数据传输,总是在一段一段的链路上传送的,这就需要使用专门的链路层的协议。在两个相邻节点之间传送数据时,数据链路层将网络层交下来的IP数据报组装成帧,在两个相邻节点间的链路上传送帧。每一帧包括数据和必要的控制信息(如同步信息,地址信息,差错控制等)。

          在接收数据时,控制信息使接收端能够知道一个帧从哪个比特开始和到哪个比特结束。这样,数据链路层在收到一个帧后,就可从中提出数据部分,上交给网络层。

          控制信息还使接收端能够检测到所收到的帧中有无差错。如果发现差错,数据链路层就简单地丢弃这个出了差错的帧,以避免继续在网络中传送下去白白浪费网络资源。如果需要改正数据在链路层传输时出现差错(这就是说,数据链路层不仅要检错,而且还要纠错),那么就要采用可靠性传输协议来纠正出现的差错。这种方法会使链路层的协议复杂些。

     

    1.5 物理层

          在物理层上所传送的数据单位是比特。物理层的作用是实现相邻计算机节点之间比特流的透明传送,尽可能屏蔽掉具体传输介质和物理设备的差异。使其上面的数据链路层不必考虑网络的具体传输介质是什么。“透明传送比特流”表示经实际电路传送后的比特流没有发生变化,对传送的比特流来说,这个电路好像是看不见的。

     

    2 TCP三次握手和四次挥手

    2.1 三次握手

          为了准确无误的把数据送达目标处,TCP协议采用了三次握手策略。

    2.1.1 三次握手简单示意图

          客户端-发送带有SYN标志的数据包-一次握手-服务端

          服务端-发送带有SYN/ACK标志的数据包-二次握手-客户端

          客户端-发送带有ACK标志的数据包-三次握手-服务端

    2.1.2 为什么要三次握手

          三次握手的目的是建立可靠的通信信道,说到通讯,简单来说就是数据的发送与接收,而三次握手最主要的目的就是双方确认自己与对方的发送与接收是正常的

          第一次握手:Client什么都不能确认;Server确认了对方发送正常

          第二次握手:Client确认了自己发送、接收正常,对方发送、接收正常;Server确认了自己接收正常,对方发送正常

          第三次握手:Client确认了自己发送、接收正常,对方发送、接收正常;Server确认了自己发送、接收正常,对方发送接收正常

          所以三次握手就能确认双方收发功能都正常,缺一不可。

    2.1.3 为什么要传回SYN

          接收端传回发送端所发送的SYN是为了告诉发送端,我接收到的信息确实就是你所发送的信号了。

     

    2.1.4 传了SYN,为啥还要传ACK

          双方通信无误必须是两者互相发送信息都无误。传了SYN,证明发送方到接收方的通信没有问题,但是接收方到发送方的通信还需要ACK信号来进行验证。

    2.2 四次挥手

    2.2.1 四次挥手简单示意图

     

          断开一个TCP连接需要“四次挥手”:

          客户端-发送一个FIN,用来关闭客户端到服务器的数据传送

          服务器-收到这个FIN,它发回来一个ACK,确认序列号为收到的序号加1。和SYN一样,一个FIN将占有一个序列

          服务器-关闭与客户端的连接,发送一个FIN给客户端

          客户端-发回ACK报文确认,并将确认序号设置为收到序号加1

    2.2.2 为什么要四次挥手

          任何一方都可以在数据传送结束后发出连接释放的通知,待对方确认后进入半关闭状态。当另一方也没有数据在发送的时候,则发出连接释放通知,对方确认后就完全关闭了TCP连接。

    3 TCP、UDP协议的区别

          UDP在传送数据之前不需要先建立连接,远的主机在收到UDP报文后,不需要给出任何确认。虽然UDP不提供可靠交付,但在某些情况下却是一种很有效的工作方式(一般用于即时通信),比如:QQ语音、QQ视频、直播等。

          TCP提供面向连接的服务。在传送数据之前必须先建立连接,数据传送结束后要释放连接。TCP不提供广播或多播服务。由于TCP要提供可靠的,面向连接的运输服务(TCP的可靠体现在TCP在传递数据之前,会有三次握手来建立连接,而且在数据传递时,有确认、窗口、重传、拥塞控制机制,在数据传完后,还会断开连接来节约系统资源),这样难以避免增加了许多开销,如确认,流量控制,计时器以及连接管理等。这不仅使协议数据单元的首部增大很多,还要占用许多处理机资源。TCP一般用于文件传输、发送和接收邮件、远程登录等场景。

    4 TCP协议如何保证可靠传输

          1.应用数据被分割成TCP认为最适合发送的数据块。

          2.超时重传:当TCP发出一个段后,它启动一个定时器,等待目的端确认收到这个报文段。如果不能及时收到一个确认,将重发这个报文段。

          3.TCP给发送的每一个包进行编号,接收方对数据包进行排序,把有序数据传送给应用层。

          4.校验和:TCP将保持它首部和数据的检验和。这是一个端到端的检验和,目的是检测数据在传输过程中的任何变化。如果收到段的检验和有差错,TCP将丢弃这个报文段和不确认收到此报文段。

          5.TCP的接收端会丢弃重复的数据。

          6.流量控制:TCP连接的每一方都有固定大小的缓冲空间,TCP的接收端只允许发送端发送接收端缓冲区能接纳的数据。当接收方来不及处理发送方的数据,能提示发送方降低发送的速率,防止包丢失。TCP使用的流量控制协议是可变大小的滑动窗口协议。(TCP利用滑动窗口实现流量控制)

          7.拥塞控制:当网络拥塞时,减少数据的发送。

          8.停止等待ARQ协议也是为了实现可靠传输的,它的基本原理就是每发完一个分组就停止发送,等待对方确认。在收到确认后再发下一个分组。

    4.1 超时重传

          停止等待协议中超时重传是指只要超过一段时间仍然没有收到确认,就重传前面发送过的分组(认为刚才发送过的分组丢失了)。因此每发送完一个分组需要设置一个超时计时器,其重传时间应比数据在分组传输的平均往返时间更长一些。这种自动重传方式常称为自动重传请求ARQ。另外在停止等待协议中若收到重复分组,就丢弃该分组,但同时还要发送确认。连续ARQ协议可提高信道利用率。发送维持一个发送窗口,凡位于发送窗口内的分组可连续发送出去,而不需要等待对方确认。接收方一般采用累积确认,对按需到达的最后一个分组发送确认,表明到这个分组位置的所有分组都已经正确收到了。

    4.2 停止等待协议

          停止等待协议是为了实现可靠传输的,它的基本原理就是每发完一个分组就停止发送,等待对方确认。在收到确认后再发下一个分组。

          为了提高传输效率,发送方可以不使用低效率的停止等待协议,而是采用流水线传输。流水线传输就是发送方可连续发送多个分组,不必每发完一个分组就停下来等待对方确认。这样可使信道上一直有数据不间断的在传送。这种传输方式可以明显提高信道利用率。

    4.3 滑动窗口

          TCP利用滑动窗口实现流量控制的机制。

          发送窗口里面的序号表示允许发送的序号。发送窗口后沿的后面部分表示已发送且已收到确认,而发送窗口前沿的前面部分表示不允许发送。发送窗口后沿的变化情况有两种可能,即不动(没有收到新的确认)和前移(收到了新的确认)。发送窗口的前沿通常是不断向前移动的。一般来说,我们总是希望数据传输更快一些。但如果发送方把数据发送得过快,接收方就可能来不及接收,这就会造成数据的丢失。所谓流量控制就是让发送方的发送速率不要太快,要让接收方来得及接收。

    4.4 流量控制

          流量控制是为了控制发送方发送速率,保证接收方来得及接收。

          接收方发送的确认报文中的窗口字段可以用来控制发送方窗口大小,从而影响发送方的发送速率。将窗口字段设置为0,则发送方不能发送数据。

    4.5 拥塞控制

          在某段时间,若对网络中某一资源的需求超过了该资源所能提供的可用部分,网络的性能就要变坏。这种情况就叫拥塞。拥塞控制就是为了防止过多的数据注入到网络中,这样就可以使网络中的路由器或链路不致过载。拥塞控制所要做的都有一个前提,就是网络能够承受现有的网络负荷。拥塞控制是一个全局性的过程,涉及到所有的主机,所有的路由器,以及与降低网络传输性能有关的所有因素。相反,流量控制往往是点对点通信量的控制,是个端到端的问题。流量控制所要做到的就是抑制发送端发送数据的速率,以便使接收端来得及接收。

    为了进行拥塞控制,TCP发送方要维持一个拥塞窗口的状态变量。拥塞控制窗口的大小取决于网络的拥塞程度,并且动态变化。发送方让自己的发送窗口取为拥塞窗口和接收方的接收窗口中较小的一个。

    TCP的拥塞控制采用了四种算法,即慢开始、拥塞避免、快重传和快恢复。在网络层也可以使路由器采用适当的分组丢弃策略,以减少网络拥塞的发生。

    4.6 慢开始

          慢开始算法的思路是当主机开始发送数据时,如果立即把大量数据字节注入到网络,那么可能会引起网络阻塞,因为现在还不知道网络的符合情况。经验表明,较好的方法是先探测一下,即有小到大逐渐增大发送窗口,也就是由小到大逐渐增大拥塞窗口数值。Cwnd初始值为1,每经过一个传播轮次,cwnd加倍。

     

      

    4.7 拥塞避免

          拥塞避免算法的思路是让拥塞窗口cwnd缓慢增大,即每经过一个往返时间RTT就把发送方的cwnd加1.

     

    4.8 快重传与快恢复

          在TCP/IP中,快速重传和恢复是一种拥塞控制算法,它能快速恢复丢失的数据包。没有FRR,如果数据包丢失了,TCP将会使用定时器来要求传输暂停。在暂停的这段时间内,没有新的或复制的数据包被发送。有了FRR,如果接收机接收到一个不按顺序的数据段,它会立即给发送方发送一个重复确认。如果发送机接收到三个重复确认,它会假定确认件指出的数据段丢失了,并立即重传这些丢失的数据段。有了FRR,就不会因为重传时要求的暂停被耽误,当有单独的数据包丢失时,快速重传和恢复(FRR)能最有效地工作。当有多个数据信息包在某一段很短的时间内丢失时,它则不能很有效地工作。

      

    在浏览器中输入url地址->> 显示主页的过程

      

    状态码

     

    类别

    原因短语

    1XX

    Information(信息性状态码)

    接收的请求正在处理

    2XX

    Success(成功状态码)

    请求正常处理完毕

    3XX

    Redirection(重定向状态码)

    需要进行附加操作以完成请求

    4XX

    Client Error(客户端错误状态码)

    服务器无法处理请求

    5XX

    Service Error(服务器错误状态码)

    服务器处理请求出错

    7 HTTP长连接、短连接

          在HTTP/1.0中默认使用短连接。也就是说,客户端和服务器每进行一次HTTP操作,就建立一次连接,任务结束就中断连接。当客户端浏览器访问的某个HTML或其他类型的Web页中包含有其他的Web资源(如JavaScript文件、图像文件、CSS文件等),每遇到这样一个Web资源,浏览器就会重新建立一个HTTP会话。

          而从HTTP/1.1起,默认使用长连接,用以保持连接特性。使用长连接的HTTP协议,会在响应头加入这行代码:

          Connection:keep-alive

          在使用长连接的情况下,当一个网页打开完成后,客户端和服务器之间用于传输HTTP数据的TCP连接不会关闭,客户端再次访问这个服务器时,会继续使用这一条已经建立的连接。Keep-Alive不会永久保持连接,它有一个保持时间,可以在不同的服务器软件(如Apache)中设定这个时间。实现长连接需要客户端和服务器端都支持长连接。

          HTTP协议的长连接和短连接,实质上是TCP协议的长连接和短连接。

    各种协议与HTTP协议之间的关系

     

  • 相关阅读:
    Fruit Ninja(随机数rand())
    C. A Mist of Florescence ----- Codeforces Round #487 (Div. 2)
    给力的移动 FZU
    FZU 2254 英语考试 (最小生成树)
    6486: An Ordinary Game(规律)
    HDU 1114: Piggy-Bank
    HDU 5916: Harmonic Value Description
    1072 威佐夫游戏
    1069 Nim游戏
    1066 Bash游戏
  • 原文地址:https://www.cnblogs.com/chenjin2018/p/9658096.html
Copyright © 2020-2023  润新知