TCP传输层详解(计算机网络复习)

简介: 本文详细解释了TCP/IP协议族的分层模型、各层的功能、TCP报文的格式以及TCP连接建立的三次握手和断开的四次挥手过程。

介绍:TCP/IP包含了一系列的协议,也叫TCP/IP协议族,简称TCP/IP。该协议族提供了点对点的连接机制,并将传输数据帧的封装、寻址、传输、路由以及接收方式都予以标准化

TCP/IP的分层模型

在讲TCP/IP协议之前,首先介绍一下七层ISO模型:

七层框架 通信协议
应用层

http、smtp、snmp、ftp、telent、sip、ssh、nfs等

表示层 xdr、asn.1、smb、afp、ncp等
会话层 ASAP、ssh、rpc、netbios、asp、winsock、bsd socket等
传输层 tcp、udp、tls、rtp、sctp、spx、atp、IL等
网络层 ip、icmp、igmp、ipx、bgp、ospe、rip等
数据链路层 以太网、HDLC、令牌环、帧中继、ISDN等
物理层 铜缆、网缆、光缆、无线电等

TCP/IP协议是互联网最基本的协议,在一定程度上参考了七层ISO模型,有些复杂,所以在TCP/IP协议中的七层被简化为四个层次。

1、TCP/IP协议的应用层

应用层包含所有和应用程序协同工作并利用基础网络交换应用程序的业务数据的协议。一些特定的程序被认为运行在这个层上,该层协议所提供的服务能直接支持用户应用。应用层协议包含HTTP(万维网服务)、ftp(文件传输)、smtp(电子邮箱)、ssh(安全远程登录)、dns(域名解析)等诸多协议。

2、TCP/IP协议的传输层

(1)传输层的协议解决了端与端连接提供传输服务。

(2)这种传输服务分为可靠和不可靠的,其中TCP就是可靠传输、udp是不可靠传输。

(3)为端与端连接提供流量控制、差错控制、服务质量等管理服务。

传输层主要有两个性质不同的协议:tcp(控制传输协议)和UDP(用户数据协议)。

TCP那边有一个接受数据的缓存区,通过这个缓存可以解决以下两个问题:

  1. 流量控制:接收端可以通过控制缓存区的大小来控制发送端的发送速率,从而避免发送端发送过快导致接收端无法处理的情况。
  2. 确认机制:接收端可以将已经接收到的数据存放在缓存区中,等待后续的数据到达,当接收到后续的数据时,可以通过确认机制通知发送端已经接收到了哪些数据,从而保证数据的可靠传输。

而UDP是一个无连接的数据报协议,它没有缓存区,实现不了TCP上面的功能,UDP的主要目的是尽力传递,其不需要搞这些复杂的操作,所以其传输效率是最高的。

3、TCP/IP协议的网络层

TCP/IP协议网络层的作用是在复杂的网络环境中为要发送的数据报找到一个合适的路径进行传输。简单来说,网络层负责将数据传输到目的地址,目的地址可以是多个网络通过路由器连接而成的某一地址。路由转发应该也是由该层完成。网络协议的代表包括ICMP、IP、IGMP等。

4、TCP/IP协议的链路层

链路层有时也被称为数据链路层或网络接口层,用来处理连接网络的硬件部分。该层既包括操作系统硬件的设备驱动、NIC(网卡)、光纤等物理可见部分,也包括连接器等一切传输媒介。在这一层中,数据的传输单位为bit(比特)。其主要协议有ARP、RARP等。

HTTP报文传输原理

利用TCP/IP进行网络通信时,数据包会按照分层顺序与对方进行通信。发送端从应用层往下走,接收端从链路层往上走。从客户端到服务端的数据,每一帧的传输顺序都为应用层->传输层->网络层->链路层->链路层->网络层->传输层->应用层。

接下来为大家介绍一下数据封装和分用。

数据通过互联网传输时不可能是光秃秃的不加标识(数据会乱),所以在发送数据时需要加上特定的标识(数据封装),在使用数据时候在去掉特定标识(数据分用)。

1、TCP报文格式

源端口号:

(1)源端口号表示报文的发送端口,占16位。源端口号和源ip地址组合起来,可以标识报文的发送地址。

(2)目的端口号表示报文的接收端口,占16位。目的端口号和目的IP地址相结合,可以标识报文的接收地址

(3)序号,TCP传输过程中,在发送端出的字节流中,传输报文中的数据部分的每一个字节都有它的编号。序号占32位,发起方发送数据时,都需要标记序号。

序号的语义与syn控制标志(Control bits)的值有关。根据控制标志中的SYN来表示不同的序号含义:

当syn=1时,为连接建立阶段

当syn=0时,为数据传输正式开始时,第一个报文的序号为isn+1,后面的报文序号为前一个报文的SN值+TCP报文的净荷字节数(不包含TCP头)。如果发送端发送的一个TCP帧的净荷为12B,序号为5 ,则发送端接着发送下一个数据包时,序号的值应该为5+12=17。

在数据传输中,tcp通过序号来对上层提供有序的数据流。

(4)确认序号标识了报文接收端期望接收的字节序列。如果设置了ACK控制位,确认序号的值表示下一个准备接收的包的序号码。举个例子

(5)头部长度,该字段占4位,用来表示tcp报文的首部长度。

(6)保留字段,暂时没什么用。

(7)控制标志占6位,具体的标志位为URG、ACK、psh、rst、syn、fin

(8)窗口,长度为16位,共两个字节,用来进行流量控制的。

(9)校验和长度位16位,共两个字节,对整个tcp报文段,即tcp头部和tcp数据进行校验和计算,接收端用于对收到的数据包进行验证。

(10)紧急指针,长度16位,共两个字节,是一个偏移量,和sn序号值相加表示紧急数据最后一个字节的序号。

以上10项内容是TCP报文首部必需字段,也叫固有字段,长度为20字节。接下来就是可选项和填充部分。

2、TCP的三次握手

TCP连接建立时,双方需要经过三次握手;断开连接时,双方需要经过四次挥手。

通常情况下,建立连接的双方由一端监听来自请求方的TCP连接,当服务端监听开始时,必须准备好接受外来的连接,在java中该操作通过创建一个ServerSocket服务监听套接字实例来完成。此操作会调用操作系统(如linux)c代码的三个函数socket()、bind()、listen()来完成

服务端伪代码如下:

import java.io.IOException;
import java.net.ServerSocket;
import java.net.Socket;

public class SocketServer {
    public static void main(String[] args) {
        try {
            ServerSocket socket=new ServerSocket(8080);
            while (true){
                Socket socket1=socket.accept();
                //开启线程进行连接的IO操作
                ServerThread thread=new ServerThread();
                thread.start();
            }
        } catch (IOException e) {
            throw new RuntimeException(e);
        }
    }
}

客户端伪代码如下:

import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import java.net.Socket;
import java.net.UnknownHostException;

public class SocketClient {
    public static void main(String[] args) {
        try {
            Socket socket =new Socket("localhost",8080);
            //写入给监听方的输出流。
            OutputStream os=socket.getOutputStream();

            //读取监听方的输入流
            InputStream inputStream=socket.getInputStream();
        } catch (UnknownHostException e) {
            throw new RuntimeException(e);
        } catch (IOException e) {
            throw new RuntimeException(e);
        }
    }
}

(1)第一次握手:Client进入SYN_SENT状态,发送一个SYN帧来主动打开传输通道,该帧被设置为1

(2)第二次握手:Server在收到SYN帧之后,会进入SYN_RCVD状态,同时返回SYN+ACK帧给client。

(3)第三次握手:Client在收到Server的第二次握手SYN+ACK确认帧之后,首先将自己的状态从SYN_SEND变成ESTABLISHED,表示自己的放向的连接通道已经建立成功。

3、TCP的四次挥手

相关实践学习
深入解析Docker容器化技术
Docker是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的Linux机器上,也可以实现虚拟化,容器是完全使用沙箱机制,相互之间不会有任何接口。Docker是世界领先的软件容器平台。开发人员利用Docker可以消除协作编码时“在我的机器上可正常工作”的问题。运维人员利用Docker可以在隔离容器中并行运行和管理应用,获得更好的计算密度。企业利用Docker可以构建敏捷的软件交付管道,以更快的速度、更高的安全性和可靠的信誉为Linux和Windows Server应用发布新功能。 在本套课程中,我们将全面的讲解Docker技术栈,从环境安装到容器、镜像操作以及生产环境如何部署开发的微服务应用。本课程由黑马程序员提供。     相关的阿里云产品:容器服务 ACK 容器服务 Kubernetes 版(简称 ACK)提供高性能可伸缩的容器应用管理能力,支持企业级容器化应用的全生命周期管理。整合阿里云虚拟化、存储、网络和安全能力,打造云端最佳容器化应用运行环境。 了解产品详情: https://www.aliyun.com/product/kubernetes
目录
相关文章
|
11月前
|
网络协议 物联网
VB6网络通信软件上位机开发,TCP网络通信,读写数据并处理,完整源码下载
本文介绍使用VB6开发网络通信上位机客户端程序,涵盖Winsock控件的引入与使用,包括连接服务端、发送数据(如通过`Winsock1.SendData`方法)及接收数据(利用`Winsock1_DataArrival`事件)。代码实现TCP网络通信,可读写并处理16进制数据,适用于自动化和工业控制领域。提供完整源码下载,适合学习VB6网络程序开发。 下载链接:[完整源码](http://xzios.cn:86/WJGL/DownLoadDetial?Id=20)
409 12
|
负载均衡 网络协议 算法
不为人知的网络编程(十九):能Ping通,TCP就一定能连接和通信吗?
这网络层就像搭积木一样,上层协议都是基于下层协议搭出来的。不管是ping(用了ICMP协议)还是tcp本质上都是基于网络层IP协议的数据包,而到了物理层,都是二进制01串,都走网卡发出去了。 如果网络环境没发生变化,目的地又一样,那按道理说他们走的网络路径应该是一样的,什么情况下会不同呢? 我们就从路由这个话题聊起吧。
401 4
不为人知的网络编程(十九):能Ping通,TCP就一定能连接和通信吗?
|
12月前
|
网络协议 测试技术 Linux
Golang 实现轻量、快速的基于 Reactor 模式的非阻塞 TCP 网络库
gev 是一个基于 epoll 和 kqueue 实现的高性能事件循环库,适用于 Linux 和 macOS(Windows 暂不支持)。它支持多核多线程、动态扩容的 Ring Buffer 读写缓冲区、异步读写和 SO_REUSEPORT 端口重用。gev 使用少量 goroutine,监听连接并处理读写事件。性能测试显示其在不同配置下表现优异。安装命令:`go get -u github.com/Allenxuxu/gev`。
294 0
|
网络协议
TCP报文格式全解析:网络小白变高手的必读指南
本文深入解析TCP报文格式,涵盖源端口、目的端口、序号、确认序号、首部长度、标志字段、窗口大小、检验和、紧急指针及选项字段。每个字段的作用和意义详尽说明,帮助理解TCP协议如何确保可靠的数据传输,是互联网通信的基石。通过学习这些内容,读者可以更好地掌握TCP的工作原理及其在网络中的应用。
|
监控 网络协议 网络性能优化
网络通信的核心选择:TCP与UDP协议深度解析
在网络通信领域,TCP(传输控制协议)和UDP(用户数据报协议)是两种基础且截然不同的传输层协议。它们各自的特点和适用场景对于网络工程师和开发者来说至关重要。本文将深入探讨TCP和UDP的核心区别,并分析它们在实际应用中的选择依据。
537 3
|
Web App开发 缓存 网络协议
不为人知的网络编程(十八):UDP比TCP高效?还真不一定!
熟悉网络编程的(尤其搞实时音视频聊天技术的)同学们都有个约定俗成的主观论调,一提起UDP和TCP,马上想到的是UDP没有TCP可靠,但UDP肯定比TCP高效。说到UDP比TCP高效,理由是什么呢?事实真是这样吗?跟着本文咱们一探究竟!
625 10
|
网络协议 算法 网络性能优化
计算机网络常见面试题(一):TCP/IP五层模型、TCP三次握手、四次挥手,TCP传输可靠性保障、ARQ协议
计算机网络常见面试题(一):TCP/IP五层模型、应用层常见的协议、TCP与UDP的区别,TCP三次握手、四次挥手,TCP传输可靠性保障、ARQ协议、ARP协议
|
域名解析 存储 网络协议
TCP套接字【网络】
TCP套接字【网络】
264 10
|
域名解析 网络协议 前端开发
【第四期】网络层、传输层、应用层
【第四期】网络层、传输层、应用层
190 3
|
网络协议 Java API
【网络】TCP回显服务器和客户端的构造,以及相关bug解决方法
【网络】TCP回显服务器和客户端的构造,以及相关bug解决方法
245 2

热门文章

最新文章