《TCP/IP详解 卷一:协议》读书笔记 - 3 IP:网际协议

本贴最后更新于 3384 天前,其中的信息可能已经渤澥桑田

#IP:网际协议
IP 是 TCP/IP 协议簇中最核心的协议。所有的 TCP、UDP、ICMP、IGMP 数据都以 IP 数据报格式传输。IP 协议提供不可靠无连接服务。


##IP 首部
IP 首部

  • 网络字节序:big endian 字节序。首先传送 0-7 bit,其次 8-15 bit,然后 16-23 bit,最后 24-31 bit。以小端格式存储的数据需要在传送前转换为大端模式。
  • 版本号:4 位,目前协议版本号为 4,因此 IP 也称为 IPv4。
  • 首部长度:4 位,首部长度,包括首部可选项,以 32 bit 为单位。最短 20 个字节,最长 60 字节。(5*(32/8)=20 字节)。
  • 服务类型:8 位,包含 3 bit 优先权子字段(现已忽略),4 bit 的 TPS 子字段,1 bit 未用但必须为 0。4 bit 的 TOS 分别代表:最小时延、最大吞吐量、最高可靠性和最小费用。
    服务类型推荐值
  • 总长度:16 位,整个 IP 数据报的长度,以字节为单位。最长可达 65535。
  • 标识(Identifier):16 位,唯一地标识主机发送的每一份数据报。
  • 标志(Flag):3 位,第一位暂不用。第二位 DF,DF=1 表明不能进行分段。若 DF=1 且数据长度过长,则会被抛弃且返回错误。第三位 MF,若对数据进行分片,则会在除最后一个分段外将 MF 设置为 1,表示后面还有更多的分段未到达。
  • 片偏移:13 位,用于对分片进行拼接。
  • 生存时间(TTL):8 位,设置数据报可以经过的最多路由数量。
  • 协议:8 位,根据它可以识别是哪个协议向 IP 传送数据,如 TCP、UDP 等。
  • 首部校验和:16 位,不对数据进行计算。

##IP 路由选择
从概念上说,IP 路由选择是简单的,特别是对于主机而言。如果目的主机和源主机直接相连或都在一个共享网络上,那么 IP 数据报就直接送到目的主机上。否则,主机把数据报发往默认路由,由该路由进行转发数据报。
路由表中的每一项包含下面信息:

  • 目的 IP 地址。
  • 下一跳路由器的 IP 地址,或直接连接的网络 IP 地址。
  • 标志。其中一个标志指明目的 IP 地址是网络地址还是主机地址,另一个标志指明下一跳路由器是否为真正的下一跳路由器,还是一个直接相连的接口。
  • 为数据报的传输指定一个网络接口。

IP 路由选择是逐跳进行的,IP 并不知道到达任何目的的完整路径。IP 路由器主要完成以下功能:

  • 搜索路由表,寻找能与目的 IP 地址完全匹配的表目。
  • 搜索路由表,寻找能与目的网络号相匹配的表目。
  • 搜索路由表,寻找标为“默认”的表目。

注:

  • 在路由寻址转发过程中数据报中的 IP 地址始终步发生任何变化,而且所有路由选择决策都是基于这个目的 IP 地址。
  • 每个链路层可能具有不通的数据帧首部,而且链路层的目的地址始终是指向下一站链路层地址。

##子网寻址
现在所有的主机都要求支持子网编址。ABC 类地址单纯地把 32 位网络地址分为网络号和主机号,这样使得每个网络中的可用的主机号太多,A 类和 B 类分别为 2^24-2 和 2^16-2(除了全 0 和全 1),然而并用不完。现在把主机号再划分为子网号和主机号,如对一个 B 类地址,前 16 位为网络号,将后 16 位主机号拆分为 8 位子网号和 8 为主机号。子网对外部路由器来说隐藏了内部网络组织(校园或公司内部)的细节。这样外部路由器仅需要知道下一跳路由的子网号,而无需知道具体的主机号,可以大大缩减路由表的规模。


##子网掩码
子网的位数是由人定的,机器并不知道子网的位数。因此需要由子网掩码来确定多少比特用于子网号。子网掩码是一个 32 bit 的值,其中值为 1 的比特留给网络号和子网号,为 0 的比特留给主机号。
给定 IP 地址和子网掩码后,主机就可以确定 IP 数据报的目的是:

  1. 本子网上的主机
  2. 本网络中其他子网的主机
  3. 其他网络上的主机

相关帖子

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...

推荐标签 标签

  • ZooKeeper

    ZooKeeper 是一个分布式的,开放源码的分布式应用程序协调服务,是 Google 的 Chubby 一个开源的实现,是 Hadoop 和 HBase 的重要组件。它是一个为分布式应用提供一致性服务的软件,提供的功能包括:配置维护、域名服务、分布式同步、组服务等。

    59 引用 • 29 回帖 • 9 关注
  • 反馈

    Communication channel for makers and users.

    120 引用 • 906 回帖 • 280 关注
  • Q&A

    提问之前请先看《提问的智慧》,好的问题比好的答案更有价值。

    10000 引用 • 45452 回帖 • 73 关注
  • 区块链

    区块链是分布式数据存储、点对点传输、共识机制、加密算法等计算机技术的新型应用模式。所谓共识机制是区块链系统中实现不同节点之间建立信任、获取权益的数学算法 。

    92 引用 • 752 回帖 • 1 关注
  • frp

    frp 是一个可用于内网穿透的高性能的反向代理应用,支持 TCP、UDP、 HTTP 和 HTTPS 协议。

    17 引用 • 7 回帖
  • 数据库

    据说 99% 的性能瓶颈都在数据库。

    345 引用 • 754 回帖
  • FFmpeg

    FFmpeg 是一套可以用来记录、转换数字音频、视频,并能将其转化为流的开源计算机程序。

    23 引用 • 32 回帖 • 1 关注
  • IBM

    IBM(国际商业机器公司)或万国商业机器公司,简称 IBM(International Business Machines Corporation),总公司在纽约州阿蒙克市。1911 年托马斯·沃森创立于美国,是全球最大的信息技术和业务解决方案公司,拥有全球雇员 30 多万人,业务遍及 160 多个国家和地区。

    17 引用 • 53 回帖 • 145 关注
  • InfluxDB

    InfluxDB 是一个开源的没有外部依赖的时间序列数据库。适用于记录度量,事件及实时分析。

    2 引用 • 98 关注
  • Gzip

    gzip (GNU zip)是 GNU 自由软件的文件压缩程序。我们在 Linux 中经常会用到后缀为 .gz 的文件,它们就是 Gzip 格式的。现今已经成为互联网上使用非常普遍的一种数据压缩格式,或者说一种文件格式。

    9 引用 • 12 回帖 • 175 关注
  • WebClipper

    Web Clipper 是一款浏览器剪藏扩展,它可以帮助你把网页内容剪藏到本地。

    3 引用 • 9 回帖 • 2 关注
  • 链书

    链书(Chainbook)是 B3log 开源社区提供的区块链纸质书交易平台,通过 B3T 实现共享激励与价值链。可将你的闲置书籍上架到链书,我们共同构建这个全新的交易平台,让闲置书籍继续发挥它的价值。

    链书社

    链书目前已经下线,也许以后还有计划重制上线。

    14 引用 • 257 回帖 • 1 关注
  • Laravel

    Laravel 是一套简洁、优雅的 PHP Web 开发框架。它采用 MVC 设计,是一款崇尚开发效率的全栈框架。

    19 引用 • 23 回帖 • 737 关注
  • PostgreSQL

    PostgreSQL 是一款功能强大的企业级数据库系统,在 BSD 开源许可证下发布。

    22 引用 • 22 回帖 • 2 关注
  • CongSec

    本标签主要用于分享网络空间安全专业的学习笔记

    1 引用 • 1 回帖 • 37 关注
  • 微信

    腾讯公司 2011 年 1 月 21 日推出的一款手机通讯软件。用户可以通过摇一摇、搜索号码、扫描二维码等添加好友和关注公众平台,同时可以将自己看到的精彩内容分享到微信朋友圈。

    133 引用 • 796 回帖
  • WebComponents

    Web Components 是 W3C 定义的标准,它给了前端开发者扩展浏览器标签的能力,可以方便地定制可复用组件,更好的进行模块化开发,解放了前端开发者的生产力。

    1 引用 • 9 关注
  • Caddy

    Caddy 是一款默认自动启用 HTTPS 的 HTTP/2 Web 服务器。

    10 引用 • 54 回帖 • 178 关注
  • Kotlin

    Kotlin 是一种在 Java 虚拟机上运行的静态类型编程语言,由 JetBrains 设计开发并开源。Kotlin 可以编译成 Java 字节码,也可以编译成 JavaScript,方便在没有 JVM 的设备上运行。在 Google I/O 2017 中,Google 宣布 Kotlin 成为 Android 官方开发语言。

    19 引用 • 33 回帖 • 78 关注
  • SQLite

    SQLite 是一个进程内的库,实现了自给自足的、无服务器的、零配置的、事务性的 SQL 数据库引擎。SQLite 是全世界使用最为广泛的数据库引擎。

    4 引用 • 7 回帖 • 4 关注
  • PHP

    PHP(Hypertext Preprocessor)是一种开源脚本语言。语法吸收了 C 语言、 Java 和 Perl 的特点,主要适用于 Web 开发领域,据说是世界上最好的编程语言。

    167 引用 • 408 回帖 • 491 关注
  • GitBook

    GitBook 使您的团队可以轻松编写和维护高质量的文档。 分享知识,提高团队的工作效率,让用户满意。

    3 引用 • 8 回帖 • 1 关注
  • Tomcat

    Tomcat 最早是由 Sun Microsystems 开发的一个 Servlet 容器,在 1999 年被捐献给 ASF(Apache Software Foundation),隶属于 Jakarta 项目,现在已经独立为一个顶级项目。Tomcat 主要实现了 JavaEE 中的 Servlet、JSP 规范,同时也提供 HTTP 服务,是市场上非常流行的 Java Web 容器。

    162 引用 • 529 回帖 • 7 关注
  • Access
    1 引用 • 3 回帖 • 3 关注
  • FlowUs

    FlowUs.息流 个人及团队的新一代生产力工具。

    让复杂的信息管理更轻松、自由、充满创意。

    1 引用 • 7 关注
  • Flume

    Flume 是一套分布式的、可靠的,可用于有效地收集、聚合和搬运大量日志数据的服务架构。

    9 引用 • 6 回帖 • 661 关注
  • 导航

    各种网址链接、内容导航。

    45 引用 • 177 回帖