详解TCP/IP五层模型

目录

一、什么是TCP五层模型?

二、TCP五层模型的详细内容

[1. 应用层](#1. 应用层)

[2. 传输层](#2. 传输层)

[3. 网络层](#3. 网络层)

[4. 数据链路层](#4. 数据链路层)

[5. 物理层](#5. 物理层)

三、网络设备所在分层

封装和分⽤

三、Java示例


引言:

在网络通信中,TCP/IP协议是至关重要的。为了更好地理解TCP协议的工作原理,我们需要了解TCP/IP模型,也称为五层模型。本文将深入探讨TCP五层模型的内容,并使用Java代码示例说明。

一、什么是TCP五层模型?

TCP/IP模型是一个网络通信体系结构,由五层组成,每一层都有其特定的功能。这五层分别是:

  1. 应用层
  2. 传输层
  3. 网络层
  4. 数据链路层
  5. 物理层

每一层都有不同的责任,通过这种层次结构,网络通信可以更有效地进行。

二、TCP五层模型的详细内容

1. 应用层

应用层是网络通信的最高层,它定义了应用程序和网络之间的接口。在这一层,用户可以直接与应用程序进行交互。常见的应用层协议有HTTP、FTP、SMTP等。

2. 传输层

传输层负责在源主机和目标主机之间建立数据传输通道。它提供了可靠的数据传输服务,确保数据的正确传输顺序和可靠性。TCP协议就是传输层协议的一种,它提供了可靠的、面向连接的数据传输服务。

3. 网络层

网络层负责在网络上寻址和路由数据包。它定义了数据在网络中的传输路径,使得数据可以从源主机传输到目标主机。常见的网络层协议有IP协议。

4. 数据链路层

数据链路层负责在物理网络上传输数据帧。它负责数据的分段和重新组装,以及物理介质的访问控制。常见的数据链路层协议有以太网协议。

5. 物理层

物理层是网络通信的最底层,它负责在物理介质上传输比特流。它定义了物理连接的特性,如电压、频率等。常见的物理层介质有光纤、双绞线等。

三、网络设备所在分层

  • 对于⼀台主机,它的操作系统内核实现了从传输层到物理层的内容,也即是TCP/IP五层模型的下四层
  • 对于⼀台路由器,它实现了从⽹络层到物理层,也即是TCP/IP五层模型的下三层
  • 对于⼀台交换机,它实现了从数据链路层到物理层,也即是TCP/IP五层模型的下两层
  • 对于集线器,它只实现了物理层

注意我们这⾥说的是传统意义上的交换机和路由器,也称为⼆层交换机(⼯作在TCP/IP五层模型的下两层)、三层路由器(⼯作在TCP/IP五层模型的下三层)。
随着现在⽹络设备技术的不断发展,也出现了很多3层或4层交换机,4层路由器。我们以下说的⽹络设备都是传统意义上的交换机和路由器。
⽹络数据传输时,经过不同的⽹络节点(主机、路由器)时,⽹络分层需要对应。
以下为同⼀个⽹段内的两台主机进⾏⽂件传输:


以下为跨⽹段的主机的⽂件传输:数据从⼀台计算机到另⼀台计算机传输过程中要经过⼀个或多个路由器

封装和分⽤

  • 不同的协议层对数据包有不同的称谓,在传输层叫做段(segment),在⽹络层叫做数据报 (datagram),在链路层叫做帧(frame)。
  • 应⽤层数据通过协议栈发到⽹络上时,每层协议都要加上⼀个数据⾸部(header),称为封装 (Encapsulation)。
  • ⾸部信息中包含了⼀些类似于⾸部有多⻓,载荷(payload)有多⻓,上层协议是什么等信息。
  • 数据封装成帧后发到传输介质上,到达⽬的主机后每层协议再剥掉相应的⾸部,根据⾸部中的 "上层协议字段" 将数据交给对应的上层协议处理。

下图为数据封装的过程

下图为数据分⽤的过程

三、Java示例

下面通过一个简单的Java示例来说明TCP五层模型的工作原理。

java 复制代码
import java.net.*;
import java.io.*;

public class TCPServer {
    public static void main(String[] args) {
        try {
            // 创建服务器套接字,监听端口8888
            ServerSocket serverSocket = new ServerSocket(8888);
            System.out.println("服务器已启动,等待客户端连接...");

            // 等待客户端连接
            Socket clientSocket = serverSocket.accept();
            System.out.println("客户端已连接,IP地址为:" + clientSocket.getInetAddress());

            // 获取客户端输入流
            BufferedReader in = new BufferedReader(new InputStreamReader(clientSocket.getInputStream()));
            // 获取服务器输出流
            PrintWriter out = new PrintWriter(clientSocket.getOutputStream(), true);

            // 读取客户端发送的数据
            String message = in.readLine();
            System.out.println("客户端发送的消息为:" + message);

            // 向客户端发送响应消息
            out.println("服务器已接收到您的消息:" + message);

            // 关闭流和套接字
            in.close();
            out.close();
            clientSocket.close();
            serverSocket.close();
        } catch (IOException e) {
            e.printStackTrace();
        }
    }
}

以上是一个简单的TCP服务器示例。它监听8888端口,并等待客户端连接。一旦客户端连接成功,就接收客户端发送的消息,并向客户端发送响应消息。

相关推荐
dreamxian14 分钟前
苍穹外卖day11
java·spring boot·后端·spring·mybatis
Veggie2621 分钟前
【Java深度学习】PyTorch On Java 系列课程 第八章 17 :模型评估【AI Infra 3.0】[PyTorch Java 硕士研一课程]
java·人工智能·深度学习
weisian15122 分钟前
Java并发编程--19-ThreadPoolExecutor七参数详解:拒绝Executors,手动掌控线程池
java·线程池·threadpool·七大参数
csdn56597385028 分钟前
Java打包时,本地仓库有jar 包,Maven打包却还去远程拉取
java·maven·jar
Demon_Hao1 小时前
JAVA通过Redis实现Key分区分片聚合点赞、收藏等计数同步数据库,并且通过布隆过滤器防重复点赞
java·数据库·redis
华科易迅1 小时前
Spring装配对象方法-注解
java·后端·spring
桌面运维家1 小时前
Win10打印机共享故障排查:权限与网络配置详解
开发语言·网络·php
众创五舟战神:l_e01202 小时前
shopee(虾皮)买家号系统搭建:安全下单攻略
网络·安全
庄周的大鱼2 小时前
分析@TransactionalEventListener注解失效
java·spring·springboot·事务监听器·spring 事件机制·事务注解失效解决
史蒂芬_丁2 小时前
C++深度拷贝例子
java·开发语言·c++