TCP/IP协议(1): IP 地址和寻址方式 —— IP 协议的基础

最近在重学计算机网络,给自己立一个 flag,有感而发的时候写关于 TCP/IP 协议栈的系列博客。

IP 地址

IP 地址(Internet Protocol address, IP address)TCP/IP 协议栈中,起着至关重要的作用。IP 地址 不仅能唯一标识与之关联的主机,还能够指出该主机在网络中的位置,以方便我们在网络中找到该主机。

“它(IP 地址)是一个名字,标识出我们(在网络中)寻找的是什么。它也是一个地址,告诉我们要找的网络设备在网络中的哪个位置。他还是一个路线,指出我们可以如何到达与之关联的网络设备的位置。”
(“A name indicates what we seek. An address indicates where it is. A route indicates how to get there.”)

IPv4(Internet Protocol version 4) 地址

IPv4 最早在 ARPANET 中使用,如今已经在几乎所有的互联网使用。
IPv4 的地址由 32 位的非负整数表示, 通常用所谓的**点分十进制(Dot-decimal notation)**表示法表示。
点分十进制表示法将 IPv4 地址用点分成四份,每份八位。然后将每个八位转换成十进制非负整数。
如下表:

点分十进制表示 二进制表示
0.0.0.0 00000000 00000000 00000000 00000000
10.0.0.1 00001010 00000000 00000000 00000001

IPv6(Internet Protocol version 6) 地址

Internet 发展早期,加入网络的网络设备数量较少, 32 位的 IPv4 地址足以应付。
但,随着近些年 Internet 的高速发展,加入的网络设备越来越多,加之 IPv4 地址不合理的分配方式,可分配 IPv4 地址越来越少。
正是由于上述原因,IETF(Internet Engineering Task Force) 提出了 IPv6 协议。

IPv6 的地址长度为 128 位,由八个被称之为字段的四个十六进制数表示。如,5f05:2000:80ad:5800:0058:0800:2023:1d71

本文主要是对 IPv4 的讲解。

IPv4 的编址方式

IPv4 地址的编址方式共经历了三个历史阶段:

  • 分类寻址IP地址 划分为五类。IP 地址网络号(net-id)主机号(host-id) 组成。路由器仅根据目的主机的网络号来转发分组,从而减小路由表所占用的存储空间以及查找路由表的时间。

A classful network is a network addressing architecture used in the Internet from 1981 until the introduction of Classless Inter-Domain Routing in 1993.

  • 划分子网:这是对原始的 分类寻址 的改进,将原始的分类寻址进一步的划分。将之前的主机号 进一步划分为 子网号(subnet-id)主机号,从而提高 IP地址 的利用率。
  • 无类别域间路由:消除了传统的 A 类, B 类, C类地址以及划分子网的概念,因而更有效地分配 IPv4 的地址。

分类网络(classful network)

传统的 IP 地址被划分为五类:

  • IP 地址管理机构在分配 IP地址 时,分配网络号,而剩下的主机号由得到该网络号的单位自行分配。从而方便管理。
  • 路由器仅根据目的主机的网络号来转发分组,从而减小路由表所占用的存储空间以及查找路由表的时间。
  • 主机号为全 0 的地址为子网的网络号主机号 为全 1 的地址为子网的广播地址, 都不能被指派。

子网划分(subnetting): 分类网络的改进

可以看出,两级 IP 地址 不够灵活, 对 IP 地址空间的利用率比较低。如, C 类地址的局域网最多分配 254 个主机号, B 类地址的局域网最多分配 65534 个主机号。如果有个单位有 255 台主机,则只能为其分配一个 B 类地址的 网络号。这样就会浪费很多 IP 地址

子网划分 将之前的主机号 进一步划分为 子网号(subnet-id)主机号,从而提高 IP地址 的利用率。

RFC950 规定, 对分类的 IPv4 地址进行划分时,子网号 不能为全 0 或全 1;

在子网网络中保留和扩展这些特殊地址的解释(全 0 = this, 全 1 = all), 这就意味着不应该将子网号为全 0 或全一的 IP 地址分配给实际子网。
( It is useful to preserve and extend the interpretation of these special addresses in subnetted networks. This means the values of all zeros and all ones in the subnet field should not be assigned to actual (physical) subnets.)

但随着无类别域间路由的广泛使用,现在全 0 和全 1 的子网号也可以使用。

  • 子网掩码寻址
    子网掩码是一个与 IP 地址相对应的 32 位二进制串。它由一串 0 和跟随的一串 1 组成。其中,1 对应于 IP 地址网络号子网号,而 0 对应于主机号。如 A 类地址用掩码表示为 255.0.0.0B 类 地址用掩码表示为 255.255.0.0C 类地址用掩码表示为 255.255.255.0

路由器将子网掩码和目标地址进行按位与操作,从而得到目标网络的网络号子网号, 进而将数据包发送到相应的网络中去。

上图的例子解释了子网划分后到达 145.13.21.5 的数据包的传输:
(1) 在第一级网络中时。各路由器用 B 类地址的掩码 255.255.0.0145.13.21.5 按位相与得到网络号 145.13.0.0。然后传递过程中遇到的路由器都将该数据包传输给 145.13.0.0 网络。
(2)在数据包到达 145.13.0.0 网络中后。145.13.0.0 网络通过子网掩码 255.255.255.0 将该网络划分为多个子网。145.13.0.0 网络中的路由器用划分子网的掩码 255.255.255.0145.13.21.5 按位相与得到网络号子网号 145.13.21.0。然后 145.13.0.0 网络内的路由器将该数据包传输给 145.13.21.0 子网。
(3) 在数据包到达 145.13.21.0 子网后。145.13.21.0 子网的路由器将数据包传输给目的主机 145.13.21.5

  • 可变长度子网掩码寻址(VLSM, Variable-Length Subnet Masking)
    上一 part 的例子中, 145.13.0.0 网络用子网掩码 255.255.255.0 将该网络分为多个子网,但是,每个子网的最大可用主机号都是固定的(254 个)。而实际工作中,根据需求不同,各个子网的规模也不同,有的子网可能只需要几个主机号,而有的子网则可能需要成千上万个主机号,这就需要更灵活的分配方式来处理。

    可变长度子网掩码 允许将网络划分为不同大小的子网, 每个主机和路由器端口除了分配一个 IP 地址,还需要配置一个子网掩码,以确定其所在子网的规模。

###无类别域间路由 (CIDR, Classless Inter-Domain Routing)

无类别域间路由可变长度子网掩码寻址的基础上,消除了传统的 A、B、C 类网络划分。和其他相关协议一起构成所谓的 超网(Supernetwork)

CIDRIP 地址分为网络前缀(network-prefix)主机号 两部分。使用 CIDR 记法(IP 地址后面加上斜线,然后写上网络前缀所占位数)记录 IP 地址。如:128.14.35.7/20

当一个单位需要 10 个主机号的 IP 地址时, 就只需给他分配一个 /12 (子网掩码为 255.255.255.240)的 CIDR 地址块,如, 128.14.32.0/12128.14.32.15/12 地址块。分配到该地址块的单位根据实际情况的需要,可以继续将这个地址块划分成更小的子网。

私有网络(private network)地址

IP address range number of addresses largest CIDR block (subnet mask)
10.0.0.0 – 10.255.255.255 16777216 10.0.0.0/8 (255.0.0.0)
172.16.0.0 – 172.31.255.255 1048576 172.16.0.0/12 (255.240.0.0)
192.168.0.0 – 192.168.255.255 65536 192.168.0.0/16 (255.255.0.0)

参考文献

TCP/IP协议(1): IP 地址和寻址方式 —— IP 协议的基础的更多相关文章

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

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

  2. IP地址和硬件地址 ARP协议

    ip地址使用在网络层以上,是一个逻辑地址,物理地址是数据链路层和物理层使用的 在发送数据的时候,数据是从上层往下层发送的,通过tcp报文->ip数据报->mac数据帧 IP地址放在数据报的 ...

  3. TCP/IP(七)之玩转HTTP协议

    前言 前面一篇的博文简单的介绍了一下属于应用层的HTTP协议,这一篇我将详细的学习HTTP协议,这也是做Web开发中一定要用到的协议.虽然我是做大数据的,但是多学习一点肯定是 没有坏处的.国庆放假7天 ...

  4. 《TCP/IP 详解 卷1:协议》第 5 章:Internet 协议

    IP 是 TCPIP 协议族中的核心协议.所有 TCP.UDP.ICMP.IGMP 数据都通过 IP 数据包(又称为 packet)来传输.IP 的英文名为 Internet Protocol,是互联 ...

  5. 《TCP/IP 详解 卷1:协议》第 4 章:地址解析协议

    链路层是经过单一链路通信的协议层. IP 网络层协议的设计目标是为跨越不同物理类型的.多节点网络的 packet ,提供主机寻址.路由操作. 在其中要注意的一点是:网络层使用的地址和底层网络硬件使用的 ...

  6. TCP/IP协议的数据传输过程详解——IP与以太网的包收发操作

    MTU:一个网络包的最大长度,以太网中一般是1500字节:(含有头部长度,包括IP头部,TCP头部,不包括MAC头部) MSS:除去头部后,一个网络包所能容纳的TCP的数据的最大长度 下图为TCP/I ...

  7. TCP/IP网络编程之地址族与数据序列

    分配IP地址和端口号 IP是Internet Protocol(网络协议)的简写,是为收发网络数据而分配给计算机的值.端口号并非赋予计算机的值,而是为区分程序中创建的套接字而分配给套接字的序号 网络地 ...

  8. 《TCP/IP详解 卷1:协议》第4章 ARP:地址解析协议

    4.1 引言 本章我们要讨论的问题是只对TCP/IP协议簇有意义的IP地址.数据链路如以太网或令牌环网都有自己的寻址机制(常常为48 bit地址),这是使用数据链路的任何网络层都必须遵从的.一个网络如 ...

  9. TCP/IP学习笔记14--IP地址 之 全局地址,私有地址

    只要明天还在,我就不会悲哀,冬雪终会悄悄融化,春雷定将滚滚而来.----<只要明天还在>,汪国真 全局地址,私有地址 , 一种为解决IP地址不足而产生的技术. 起初 ,互联网中的任何一台主 ...

  10. IP、子网的详述 ——IP分类、网关地址,子网掩码、子网作用(转)

    IP地址    在Internet上连接的所有计算机,从大型机到微型计算机都是以独立的身份出现,我们称它为主机.为了实现各主机间的通信,每台主机都必须有一个唯一的网络地址.就好像每一个住宅都有唯一的门 ...

随机推荐

  1. 关于windows7打不开hlp文件的解决方法

    前言 其实也不是打不开,而是打开后是这样的. 也就是相当于打不开. 解决方案 安装对应架构版本补丁,重启电脑即可. 下载地址 包含64位和32位. 有能力的还望下载这个 下载地址 给我留点积分,感谢!

  2. 07#Web 实战:实现 GitHub 个人主页项目拖拽排序

    实现效果图 GitHub 和 Gitee 个人主页中可以对自己的项目进行拖拽排序,于是我就想自己实现一个.本随笔只是记录一下大概的实现思路,如果感兴趣的小伙伴可以通过代码和本随笔的说明去理解实现过程. ...

  3. js this获取元素ID

    <table id="cyyj_table" class="table01" cellpadding="5" cellspacing= ...

  4. 4.11:Storm之WordCount

    〇.概述 1.拓扑结构 2.目标 使用storm进行计数实验. 一.启动服务   在网页中输入:http://localhost:8081可以查看storm的相关信息. 二.kafka操作 终端中输入 ...

  5. 【Java SE进阶】Day04 Map、Debug

    一.Map集合 1.概述 映射 /双列集合 集合分为Collection(存储一个元素 )和Map(存储一对元素) 键不能重复,值可以重复 2.常用子类 HashMap 哈希表存储数据 元素存取数据不 ...

  6. Py2neo:一种快速导入百万数据到Neo4j的方式

    Py2neo:一种快速导入百万数据到Neo4j的方式 Py2neo是一个可以和Neo4j图数据库进行交互的python包.虽然py2neo操作简单方便,但是当节点和关系达几十上百万时,直接创建和导入节 ...

  7. 当我们的执行 java -jar xxx.jar 的时候底层到底做了什么?

    大家都知道我们常用的 SpringBoot 项目最终在线上运行的时候都是通过启动 java -jar xxx.jar 命令来运行的. 那你有没有想过一个问题,那就是当我们执行 java -jar 命令 ...

  8. 【基于OpenAI的ChatGPT】搭建属于自己的微信聊天机器人(附带注册英国手机号码方式)

    前言:这几天 OpenAI的聊天机器人很火,前两天也爆发了很多关于ChatGPT接入微信的文章.我就顺便[借用别人已有的项目],来部署一个属于自己的微信聊天机器人.项目地址见下文. 1.首先需要有一个 ...

  9. docker registry(私库)搭建,使用,WEB可视化管理部署

    Docker Registry 是Docker官方一个镜像,可以用来储存和分发Docker镜像.目前比较流行的两个镜像私库是Docker Registry ,HarBor 其中HarBor最合适企业级 ...

  10. 粘包、struct模块、进程并行与并发

    目录 粘包现象 struct模块 粘包代码实战 udp协议(了解) 并发编程理论 多道技术 进程理论 进程并行与并发 进程的三状态 粘包现象 1.服务端连续执行三次recv 2.客户端连续执行三次se ...