三 工具虽微小 入门不可少

Linux使用ifconfig、Windows使用ipconfig

所谓见微知著,这两个命令虽然是最简单的 IP 查询工具,可是世间最厉害的就是最简单的用到极致,便勘破一切,大道至简。

闲话少叙,诸位请跟随我走入浩瀚汪洋的网络命令起点,去领略计算机大神们创造的世界。

既然都是有志于我门之人,咱们还是从旁人接触少的 Linux 系统说起。

在 Linux 系统之下,除了刚开始提到的 ifconfig 命令,还有 ip addr 命令也能达到类似效果。这二者的渊源,出自于 net-tools 和 iptoute2 两个软件包,当然这两个软件包的爱恨情仇一时半会儿也说不清楚,以后有机会给大家详解。

当我们登录到 Linux 系统,来敲入 ip addr,输入如下内容:

ip addr

1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN

    link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00

    inet 127.0.0.1/8 scope host lo

       valid_lft forever preferred_lft forever

    inet6 ::1/128 scope host

       valid_lft forever preferred_lft forever

2: eth0: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast state UP qlen 1000

    link/ether 8e:5f:34:c9:ec:90 brd ff:ff:ff:ff:ff:ff

    inet 10.6.0.28/24 brd 10.6.0.255 scope global eth0

       valid_lft forever preferred_lft forever

    inet6 fe80::8c5f:34ff:fec9:ec90/64 scope link

我们首要关注的就是 IP 地址(inet 10.6.0.28/24),IP 地址就是我们现实世界中的地址号码,自然这个地址号码是不能重复的,不然别人根本就找不到你。联想到我们平时网络排障的时候遇到的 IP 地址冲突,导致网络故障。

10.6.0.28 就是一个 IP 地址,点分十进制的方式分成了四个段,每个段为 8 bit,所以 IP 地址总共是 4 * 8 = 32 bit,到了如今已经枯竭了,至于应对方法,大神们早就准备好了,我们以后再说。

IP 地址又被分成了A、B、C、D、E五类,A、B、C 日常使用,D、E 为组播和保留使用。

每个 IP 地址有两个标识 ID ,分别为网络 ID 和 主机 ID。

同一个网络 ID ,即我们常说的同一个网段,在里面的主机 ID 是可以直接通信的。

五类的网络 ID 详情如下:

A 类地址:以 0 开头,第一个字节范围:0~127;

B 类地址:以 10 开头,第一个字节范围:128~191;

C 类地址:以 110 开头,第一个字节范围:192~223;

D 类地址:以 1110 开头,第一个字节范围为 224~239;

E 类地址:以 1111 开头,保留地址

下面这个表格,详细地展示了 A、B、C 三类地址所能包含的主机的数量。

 三 工具虽微小 入门不可少

 

 

 三 工具虽微小 入门不可少

 

 

无类型域间选路(CIDR)

我们看到命令输出的是inet 10.6.0.28/24,有一个“/24”的后缀,既然我们刚刚说到网段,那么怎么计算主机 ID 是否在同一个网段内?就是靠这个称为子网掩码的后缀来计算。

子网掩码是子网特征的表现,也是 32 bit,网络位全是 1 ,主机位全是 0 。我们看到命令输出的子网络掩码就是11111111.11111111.11111111.00000000,写成十进制就是255.255.255.0,有一个广播地址brd 10.6.0.255,如果发送这个地址,所有在10.6.0网段内的主机都能收到。

有了子网掩码,我们就能很容易的判断若干个 IP 地址是否在同一个子网内?

方法将若干个 IP 地址与子网掩码分别进行 AND 运算(两个数位都为1,运算结果为1,否则为0),然后比较结果是否相同,如果是的话,就表明它们在同一个子网络中,否则就不是。

 

公有 IP 地址和私有 IP 地址

 三 工具虽微小 入门不可少

 

 

以上表格展示的就是我们一般家里面、办公室或者学校里面的 IP 地址,这样的话这些组织内部的 IT 管理人员能够自主管理、分配甚至可以和其他组织内的地址重复。

公有 IP 地址需要和运营商购买,比如说提供对外服务的网站、APP之类的。

 

咱们继续看命令的输出“scope global eth0”,global 是对外的,可以接收主机以外的包。

“inet 127.0.0.1/8 scope host lo”,lo 是loopback,又称环回接口,往往会被分配到 127.0.0.1 这个地址。这个地址用于本机通信,经过内核处理后直接返回,不会在任何网络中出现。

 

link/ether 8e:5f:34:c9:ec:90 brd ff:ff:ff:ff:ff:ff,这就是 MAC 地址,是十六进制方式表示,共有6 byte。

MAC 地址是同一个网段使用,当然要保证不能冲突,如果要跨网段,还是得依赖 IP 地址。

 

eth0: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast state UP qlen 1000

“BROADCAST,MULTICAST,UP,LOWER_UP”是net_device flags,网络设备的状态标识。

“BROADCAST”表示网卡具备广播地址,可以发送广播包。

“MULTICAST”表示可以发送多播包。

“UP”表示网卡处于启用的状态。

“LOWER_UP”表示接着网线,网卡灯状态正常。

 

mtu 1500 qdisc pfifo_fast state UP qlen 1000

“mtu 1500” 最大传输单元 MTU 为 1500,这是以太网的默认值。

“qdisc”全称是 queueing discipline,中文叫排队规则。

最简单的qdisc是pfifo,不对进入的数据包做处理,采用先入先出的方式。

而我们使用命令输出的是pfifo_fast,它是使用三个波段(band)。在每个波段里面,使用先进先出规则。优先级是band 0最高,band 2次之,band 3再次之。

如果数据包在 band 0里面,那么 band 1的数据包就不会得到处理,band 1 和 band 2 类似之。

这三个波段(band)是由服务类型(Type of Service,TOS)分配的,由它来决定优先级的顺序。

 

 

上一篇:GDAL笔记--chapter9


下一篇:【网络·笔记】ip addr/ip a命令部分输出参数