TCP/IP协议(5): IP(Internet Protocol) 协议 —— 连接各个网络的协议

关于 IP(Internet Protocol) 协议

IP(Internet Protocol) 协议TCP/IP 协议族 中的核心协议。 IP 协议根据数据 包(Packet) 中的 IP 地址, 为上层协议提供一种 无连接(Connectionless), 尽力而为(Best-effort Delivery) 的数据传输功能。

  • 尽力而为的交付(Best-effort Delivery) 用于描述既不保证数据成功交付, 也不保证数据交付满足某种服务质量的网络服务。在尽力交付的网络中,所有的用户获得的都是尽力交互的服务,这就意味着他们传输数据的比特率、延迟和丢失受当前网络的流量负载情况的影响而变化。
    (Best-effort delivery describes a network service in which the network does not provide any guarantee that data is delivered or that delivery meets any quality of service. In a best-effort network, all users obtain best-effort service, meaning that they obtain unspecified variable bit rate and latency and packet loss, depending on the current traffic load. )
  • 无连接通信(Connectionless Communication) 是一种数据交换网络的数据传输方法。在该网络中, 每个数据单元是根据其携带的信息独立寻址和路由,而不是像面向连接通信那样预先设置固定的数据通道。
    (Connectionless communication is a data transmission method used in packet switching networks in which each data unit is individually addressed and routed based on information carried in each unit, rather than in the setup information of a prearranged, fixed data channel as in connection-oriented communication.)

IP 协议的主要内容

IP 协议的主要内容如下图,该例子将会在本部分的最后一小节详细介绍。

在电信技术中, 协议数据单元(Protocol Data Unit, PDU) 表示在计算机网络的对等实体间作为单个单元传输的信息。
OSI 模型中的前四层相关的协议数据单元如下:

  • 物理层(第一层)PDU位(bit)
  • 数据链路层(第二层)PDU帧(frame)
  • 网络层(第三层)PDU包(packet)
  • 传输层(第四层)TCP 协议PDU段(segment)UDP 协议PDU数据报(datagram)

(In telecommunications, a protocol data unit (PDU) is information that is transmitted as a single unit among peer entities of a computer network.
Protocol data units are relevant in relation to each of the first four layers of the OSI model as follows:

  • The physical layer (layer 1) PDU is the bit.
  • The data link layer (layer 2) PDU is the frame.
  • The network layer (layer 3) PDU is the packet.
  • The transport layer(layer 4) PDU is the segment for TCP or the datagram for UDP.)

分片(Fragment)

网络层接收到上层协议的协议数据单元(Protocol Data Unit, PDU) 后,会在前面加上 IP 协议首部,封装成 IP 数据包

由于数据链路层有效载荷的最大传输单元(Maximum Transmission Unit, MTU) 限制,如果上层协议的 PDU 加上 IP 首部长度大于 MTU网络层会将上层协议的 PDU 拆分给多个 IP 数据包,这个操作被称之为分片(Fragment)

IP 协议 本身是不保证数据顺序传输,因此需要分片后的 IP 首部 能提供 IP 数据包 的相关字段来复原上层协议 PDU。这些字段包括:

  • 标识(Identification): 用于标识哪些分片属于同一个上层 PDU标识(Identification)
  • 标记(Flag):用于判断当前分片后面是否还有分片以及是否不能分片
  • 片偏移(Fragment Offset):用于记录当前分片在原上层 PDU 中的相对位置。

最大传输单元(MTU) 是用八位字节指定的可以用在基于传输的网络,如因特网,传输的最大的大小。在 Windows 95 中, 默认的 MTU 设为 1500 字节,部分是因为这是以太网的标准 MTU因特网实际上的 MTU 是 576 字节, 但是 ISP 通常建议使用 1500 字节。
(A maximum transmission unit (MTU) is the largest size packet or frame, specified in octets (eight-bit bytes), that can be sent in a packet-based or frame-based network such as the Internet. In Windows 95, the default MTU was 1500 octets (eight-bit bytes), partly because this is the Ethernet standard MTU. The Internet de facto standard MTU is 576, but ISPs often suggest using 1500. )

IP 包转发(Forwarding)

当主机将数据通过 TCP/IP 协议栈将数据封装成后,通过局域网协议(如:以太网协议(IEEE 802.3)Wi-Fi 协议(IEEE 802.11)) 将数据传输到当前局域网网关(Gateway)

网关接收到数据后,拆开数据,查看 IP 数据包 首部的目的 IP 地址。然后根据目的 IP 地址以及路由协议转发该数据

IP 网络中,客户端自动将目标地址在给定子网掩码指定的网络之外的 IP 数据包发送给网关。如,一个网络号为 192.168.0.0, 子网掩码为 255.255.255.0 的私有网络中,目的地址不是 192.168.0.X 的数据将会被发送给该网络的网关。在转发 IP 数据包到其他网络时,网关可能会执行网络地址转换(Network Address Translation, NAT) 操作。
(On an Internet Protocol (IP) network, clients automatically send IP packets with a destination outside a given subnet mask as defined by a combination of network address and subnet mask to a network gateway. For example, if a private network has a base IP address of 192.168.0.0 and has a subnet mask of 255.255.255.0, then any data going to an IP address outside of 192.168.0.X will be sent to that network’s gateway. While forwarding an IP packet to another network, the gateway might or might not perform Network Address Translation.)

生存时间(Time To Live, TTL)

IP 数据包在网络间转发过程中,很可能会“迷路”或进入循环网络,造成网络堵塞。在 IP 首部TTL字段通过控制 IP 数据包 存活的 跳数,以避免“迷路”的 IP 数据包长期占据网络带宽。

首部校验和(Header Checksum)

数据帧到达目标主机/路由器后,会拆掉它的MAC 首部尾部,恢复成 IP 数据包。然后根据 IP 首部首部校验和简单地校验数据传输是否正确。如果正确,则路由器会继续将其封装成,传输给下一跳。

重组(Reassembly)

分片封装成的 IP 数据包 到达完全,校验成功后,通过 IP 首部标识(Identification)标记(Flag)片偏移(Fragment Offset) 字段将分片的上层 PDU 重组。

例子详解

  • 分片主机 A 将上层 PDU 分片打包成 IP 数据包,然后封装成,发送到局域网中。
  • 转发数据帧主机 A 所在的局域网 L1中找不到地址为 IP(B) 的主机,于是将该数据帧发给网关路由器 R1路由器 R1 拆开该数据帧,查看IP 数据包 首部的目的 IP 地址 ,然后根据IP 地址将该数据帧转发到相应的网络 Net1
  • TTL路由器转发数据帧时,会打开其负载的数据包,查看 TTL 值。当 TTL 值为 0 时,路由器会丢弃该数据包。否则路由器会将 TTL的值减一,然后封装成,传输给下一跳。
  • 首部校验和数据帧Net1 路由到 路由器 R1,发送到 局域网 L2中。根据局域网协议,该数据帧最终被主机 B 接收。在传输过程中遇到的 路由器/主机 将拆掉数据帧MAC 首部尾部,得到其负载的 IP 数据包。然后根据 IP 首部首部校验和简单地校验数据传输是否正确。如果不正确,则直接丢弃该 IP 数据包,不做差错处理(上层协议会做处理)。
  • 重组:分片封装成的 IP 数据包到达完全,校验成功后,通过 IP 首部标识(Identification),标记(Flag)片偏移(Fragment Offset) 字段将分片的上层 PDU 重组。

IP 协议包(Packet)

  • 版本(Version):4位。IPv4 是 4, IPv6 是 6。
  • Internet 首部长度(Internet Header Length, IHL):4位。IPv4 的首部长度(单位: 32位字)。
  • 服务类型(Type of Service, ToS):8位。现在分为用于支持不同服务的 区分服务(Differentiated Services, DiffServ) 字段(前 6 位) 和用于拥塞控制的显示拥塞控制(Explicit Congestion Notification , ECN) 字段(后 2 位)。
  • 总长度(Total Length):16位。IP 数据包首部和数据的总长度(单位:字节)。
  • 标识(Identification): 16位。对数据包进行编号,同一个的上层 PDU 分片得到的各个 IP 数据包 编号相同。标识字段用于分片后的重组。
  • 标志(Flag):3位。最低位记为 MF(More Fragment), 当 MF = 1 时,表示后面还有与当前数据包分片自同一上层 PDU数据包。中间为记为 DF(Don’t Fragment), 当 DF = 0 时,才允许分片。最高位保留,必须置为 0。
  • 片偏移(Fragment Offset):13位。上层 PDU 分片后的 IP 数据包 在原 PDU 中的相对偏移位置。偏移单位是 8 字节。也就是说,每个分片的长度一定是 8 字节(64 位) 的整数倍
  • 生存时间(Time To Live, TTL):8位。该 数据包 最多经过的路由器个数。每经过一个路由器,该值减一。当 TTL 为 0 时,路由器丢弃该 数据包
  • 协议(Protocol): 8位。指出当前数据包携带的数据是使用哪种协议。如,ICMP 是 1, IGMP 是 2, TCP 是 6, UDP 是 17。
  • 首部校验和(Header Checksum):16位。简单校验数据包首部是否出差错。如果出错,则直接丢弃。每经过一个路由器都会计算一下首部校验和,因为首部TTL 等字段可能会发生改变。
  • 源地址(Source address): 32 位。
  • 目标地址(Destination address): 32位。
  • 选项(Options):不常用。

参考文献

TCP/IP协议(5): IP(Internet Protocol) 协议 —— 连接各个网络的协议的更多相关文章

  1. IP协议号 IP首部中有8位协议号,用于指明IP的上层协议.

    IP协议号   IP首部中有8位协议号,用于指明IP的上层协议. 0 HOPOPT IPv6 逐跳选项 1 ICMP Internet 控制消息 2 IGMP Internet 组管理 3 GGP 网 ...

  2. TCP/IP协议和IP

    理解 使用网络能够把多方链接在一起,然后可以进行数据传递 所谓的网络编程就是,让在不同的电脑上的软件能够进行数据传递,即进程之间的通信 tcp/ip简介 1. 什么是协议 有的说英语,有的说中文,有的 ...

  3. IEEE1588精密网络同步协议(PTP)

    1  引言 以太网技术由于其开放性好.价格低廉和使用方便等特点,已经广泛应用于电信级别的网络中,以太网的数据传输速度也从早期的10M提高到100M,GE,10GE.40GE,100GE正式产品也于20 ...

  4. 脚本设置IP bat 命令行设置自动获取IP和固定IP

    由于办公室网络需要固定IP和DNS才能上网, 在连接公共网络或者家里又需要自动获取IP和DNS才能上网. 频繁手动切换很麻烦,就搞了两个脚本一键设置. 1.新建文本文件, 命名为固定IP.bat 复制 ...

  5. TCP/IP 中文译名为传输控制协议/因特网互联协议,又叫网络通讯协议

    原文地址:http://hi.baidu.com/albyuyrgqgbbhoq/item/65006d2d002ab33195f62ba1 TCP/IP(Transmission Control P ...

  6. 一些重要的计算机网络协议(IP、TCP、UDP、HTTP)

    一.计算机网络的发展历程 1.计算机网络发展 与其说计算机改变了世界,倒不如说是计算机网络改变了世界.彼时彼刻,你我都因网络而有了交集,岂非一种缘分? 计算机与网络发展大致经历如下过程:

  7. 结合Wireshark捕获分组深入理解TCP/IP协议之IP协议

    摘要:     本文简单介绍了网络层理论知识,详细讲解了IP数据报各个字段,并从Wireshark俘获分组中选取IP数据报进行分析,也阐述了分组和分片的区别.   一.IPv4数据报     网络层是 ...

  8. 网络协议: TCP/IP 和UDP/IP

    网络协议: TCP/IP 和UDP/IP TCP/IP TCP/IP(Transmission Control Protocol/Internet Protocol)是一种可靠的网络数据传输控制协议. ...

  9. TCP/IP笔记(四)IP协议

    前言 IP相当于OSI参考模型的第3层--网络层:主要作用是"实现终端节点之间的通信"又称"点对点通信". IP作为整个TCP/IP中至关重要的协议,主要负责将 ...

  10. TCP/IP笔记(五)IP协议相关技术

    IP旨在让最终目标主机收到数据包,但是在这一过程中仅仅有IP时无法实现通信的.必须还要又能够解析主机名称和MACdivide功能,以技术包在发送过程中异常情况处理的功能. 这篇主要介绍下DNS.ARP ...

随机推荐

  1. (工具) 性能测试基准软件 lmBench (待补充)

    1. lmBench 介绍 Lmbench是一套简易,可移植的,符合ANSI/C标准为UNIX/POSIX而制定的微型测评工具.一般来说,它衡量两个关键特征:反应时间和带宽.Lmbench旨在使系统开 ...

  2. CPU cache知识 —— ARM架构cache结构和细节

    cache如何寻址 处理器访问cache时,cache电路会将CPU地址进行解码,分成3个部分,分别是: offset: 用于某个cache line -- 字抽取: index: 用于匹配某个cac ...

  3. MySQL进阶实战5,为什么查询速度会慢

    一.先了解一下MySQL查询的执行过程 MySQL在查询时,它是由很多子任务组成的,每个子任务都会消耗一定的时间,如果要想优化查询,实际上要优化其子任务,可以消除一些子任务.减少子任务的执行次数.让子 ...

  4. from表单前后端数据编码格式-Ajax发送json格式数据-Ajax发送文件-Django自带序列化组件-Ajax结合sweetalert

    目录 一:前后端传输数据的编码格式(contentType) 1.研究post请求数据的编码格式 2.可以朝后端发送post请求的方式 3.前后端传输数据的编码格式 4.研究form表单 5.当for ...

  5. python连接MySQL数据库实现(用户登录测试功能)pymysql

    pymysql PyMySQL 是一个纯 Python 实现的 MySQL 客户端操作库,支持事务.存取过程.批量执行,实现增删改查等 # 注册 def register(cursor): usern ...

  6. 电脑无法自动获取ip地址

    1.按下win+r,输入cmd,打开命令提示符;2.执行ipconfig命令看下能否获取到ip地址:3.若不能,执行ipconfig /renew命令重新获取ip:4.执行ipconfig命令看下能否 ...

  7. if-else 的优美写法

    前言‍♂️ 相信大家或多或少都接触过拥有庞大 if else 的项目代码吧,多重嵌套的 if else 在维护的时候真的让人很恼火,有时候一个 bug 排查下来,严重感觉身体被掏空. 本文并未有消灭或 ...

  8. [python] 基于paramiko库操作远程服务器

    SSH(Secure Shell)是一种网络安全协议,能够使两台计算机安全地通信和共享数据.目前,SSH协议已在世界各地广泛使用,大多数设备都支持SSH功能.SSH的进一步说明见:深入了解SSH.SS ...

  9. [深度学习] ubuntu18.04配置深度学习环境笔记

    最近装过很多ubuntu18.04系统的nvidia驱动,cuda10.2,cudnn7.6.5,发现每次都会出现一些小问题.总结了具体步骤,做个记录.主要分为三个步骤:驱动安装,cuda安装,cud ...

  10. 使用Python库pyqt5制作TXT阅读器(一)-------UI设计

    项目地址:https://github.com/pikeduo/TXTReader PyQt5中文手册:https://maicss.gitbook.io/pyqt-chinese-tutoral/p ...