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

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

#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. 其他网络上的主机

相关帖子

欢迎来到这里!

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

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

推荐标签 标签

  • SVN

    SVN 是 Subversion 的简称,是一个开放源代码的版本控制系统,相较于 RCS、CVS,它采用了分支管理系统,它的设计目标就是取代 CVS。

    29 引用 • 98 回帖 • 689 关注
  • abitmean

    有点意思就行了

    29 关注
  • IDEA

    IDEA 全称 IntelliJ IDEA,是一款 Java 语言开发的集成环境,在业界被公认为最好的 Java 开发工具之一。IDEA 是 JetBrains 公司的产品,这家公司总部位于捷克共和国的首都布拉格,开发人员以严谨著称的东欧程序员为主。

    180 引用 • 400 回帖
  • B3log

    B3log 是一个开源组织,名字来源于“Bulletin Board Blog”缩写,目标是将独立博客与论坛结合,形成一种新的网络社区体验,详细请看 B3log 构思。目前 B3log 已经开源了多款产品:SymSoloVditor思源笔记

    1083 引用 • 3461 回帖 • 261 关注
  • RYMCU

    RYMCU 致力于打造一个即严谨又活泼、专业又不失有趣,为数百万人服务的开源嵌入式知识学习交流平台。

    4 引用 • 6 回帖 • 51 关注
  • GitBook

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

    3 引用 • 8 回帖
  • Kafka

    Kafka 是一种高吞吐量的分布式发布订阅消息系统,它可以处理消费者规模的网站中的所有动作流数据。 这种动作(网页浏览,搜索和其他用户的行动)是现代系统中许多功能的基础。 这些数据通常是由于吞吐量的要求而通过处理日志和日志聚合来解决。

    35 引用 • 35 回帖 • 4 关注
  • Shell

    Shell 脚本与 Windows/Dos 下的批处理相似,也就是用各类命令预先放入到一个文件中,方便一次性执行的一个程序文件,主要是方便管理员进行设置或者管理用的。但是它比 Windows 下的批处理更强大,比用其他编程程序编辑的程序效率更高,因为它使用了 Linux/Unix 下的命令。

    122 引用 • 73 回帖 • 1 关注
  • Ubuntu

    Ubuntu(友帮拓、优般图、乌班图)是一个以桌面应用为主的 Linux 操作系统,其名称来自非洲南部祖鲁语或豪萨语的“ubuntu”一词,意思是“人性”、“我的存在是因为大家的存在”,是非洲传统的一种价值观,类似华人社会的“仁爱”思想。Ubuntu 的目标在于为一般用户提供一个最新的、同时又相当稳定的主要由自由软件构建而成的操作系统。

    123 引用 • 168 回帖
  • CentOS

    CentOS(Community Enterprise Operating System)是 Linux 发行版之一,它是来自于 Red Hat Enterprise Linux 依照开放源代码规定释出的源代码所编译而成。由于出自同样的源代码,因此有些要求高度稳定的服务器以 CentOS 替代商业版的 Red Hat Enterprise Linux 使用。两者的不同在于 CentOS 并不包含封闭源代码软件。

    238 引用 • 224 回帖
  • LeetCode

    LeetCode(力扣)是一个全球极客挚爱的高质量技术成长平台,想要学习和提升专业能力从这里开始,充足技术干货等你来啃,轻松拿下 Dream Offer!

    209 引用 • 72 回帖
  • Quicker

    Quicker 您的指尖工具箱!操作更少,收获更多!

    25 引用 • 83 回帖
  • 开源中国

    开源中国是目前中国最大的开源技术社区。传播开源的理念,推广开源项目,为 IT 开发者提供了一个发现、使用、并交流开源技术的平台。目前开源中国社区已收录超过两万款开源软件。

    7 引用 • 86 回帖
  • jsDelivr

    jsDelivr 是一个开源的 CDN 服务,可为 npm 包、GitHub 仓库提供免费、快速并且可靠的全球 CDN 加速服务。

    5 引用 • 31 回帖 • 53 关注
  • Webswing

    Webswing 是一个能将任何 Swing 应用通过纯 HTML5 运行在浏览器中的 Web 服务器,详细介绍请看 将 Java Swing 应用变成 Web 应用

    1 引用 • 15 回帖 • 632 关注
  • CloudFoundry

    Cloud Foundry 是 VMware 推出的业界第一个开源 PaaS 云平台,它支持多种框架、语言、运行时环境、云平台及应用服务,使开发人员能够在几秒钟内进行应用程序的部署和扩展,无需担心任何基础架构的问题。

    5 引用 • 18 回帖 • 155 关注
  • SSL

    SSL(Secure Sockets Layer 安全套接层),及其继任者传输层安全(Transport Layer Security,TLS)是为网络通信提供安全及数据完整性的一种安全协议。TLS 与 SSL 在传输层对网络连接进行加密。

    69 引用 • 190 回帖 • 483 关注
  • SQLite

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

    4 引用 • 7 回帖 • 1 关注
  • WebComponents

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

    1 引用 • 15 关注
  • InfluxDB

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

    2 引用 • 60 关注
  • Google

    Google(Google Inc.,NASDAQ:GOOG)是一家美国上市公司(公有股份公司),于 1998 年 9 月 7 日以私有股份公司的形式创立,设计并管理一个互联网搜索引擎。Google 公司的总部称作“Googleplex”,它位于加利福尼亚山景城。Google 目前被公认为是全球规模最大的搜索引擎,它提供了简单易用的免费服务。不作恶(Don't be evil)是谷歌公司的一项非正式的公司口号。

    49 引用 • 192 回帖 • 1 关注
  • HBase

    HBase 是一个分布式的、面向列的开源数据库,该技术来源于 Fay Chang 所撰写的 Google 论文 “Bigtable:一个结构化数据的分布式存储系统”。就像 Bigtable 利用了 Google 文件系统所提供的分布式数据存储一样,HBase 在 Hadoop 之上提供了类似于 Bigtable 的能力。

    17 引用 • 6 回帖 • 58 关注
  • VirtualBox

    VirtualBox 是一款开源虚拟机软件,最早由德国 Innotek 公司开发,由 Sun Microsystems 公司出品的软件,使用 Qt 编写,在 Sun 被 Oracle 收购后正式更名成 Oracle VM VirtualBox。

    10 引用 • 2 回帖 • 10 关注
  • 智能合约

    智能合约(Smart contract)是一种旨在以信息化方式传播、验证或执行合同的计算机协议。智能合约允许在没有第三方的情况下进行可信交易,这些交易可追踪且不可逆转。智能合约概念于 1994 年由 Nick Szabo 首次提出。

    1 引用 • 11 回帖 • 10 关注
  • frp

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

    16 引用 • 7 回帖 • 1 关注
  • App

    App(应用程序,Application 的缩写)一般指手机软件。

    90 引用 • 383 回帖 • 1 关注
  • Oracle

    Oracle(甲骨文)公司,全称甲骨文股份有限公司(甲骨文软件系统有限公司),是全球最大的企业级软件公司,总部位于美国加利福尼亚州的红木滩。1989 年正式进入中国市场。2013 年,甲骨文已超越 IBM,成为继 Microsoft 后全球第二大软件公司。

    103 引用 • 126 回帖 • 442 关注