2024-02-19 17:46:11 +08:00
|
|
|
|
---
|
|
|
|
|
title: IP 网际协议
|
|
|
|
|
description: IP 网际协议
|
|
|
|
|
keywords:
|
|
|
|
|
- IP
|
|
|
|
|
- 网际协议
|
|
|
|
|
- 网络协议
|
|
|
|
|
tags:
|
|
|
|
|
- 计算机网络/IP协议
|
2024-04-26 21:42:22 +08:00
|
|
|
|
- 技术/计算机网络
|
2024-02-19 17:46:11 +08:00
|
|
|
|
author: 仲平
|
|
|
|
|
date: 2024-01-15
|
|
|
|
|
---
|
|
|
|
|
|
|
|
|
|
## IP 协议基础理论
|
|
|
|
|
|
|
|
|
|
互联网协议(IP)是一种无连接的网络层协议,它是互联网的基础。IP 协议主要负责将数据包从源主机传送到目的主机,无论这两台主机位于何处。IP 协议是一个路由协议,意味着它可以动态地选择数据包从一个网络节点到另一个网络节点的路径。
|
|
|
|
|
|
|
|
|
|
### IP 协议在 OSI 模型中的位置
|
|
|
|
|
|
|
|
|
|
OSI 模型是一个参考模型,用于描述和理解复杂的网络通信过程。在这个模型中,IP 协议位于第三层,即网络层。网络层负责数据包的路由和转发,确保数据能够通过网络找到正确的目的地。
|
|
|
|
|
|
|
|
|
|
### 与 TCP/UDP 的关系
|
|
|
|
|
|
|
|
|
|
- **TCP(传输控制协议)**:位于传输层,与 IP 协议结合使用,提供可靠的、面向连接的数据传输服务。
|
|
|
|
|
- **UDP(用户数据报协议)**:也位于传输层,但提供的是简单的、无连接的服务。与 IP 结合时,UDP 允许数据包在不同的网络设备间传送,但不保证数据包的可靠传输。
|
|
|
|
|
|
|
|
|
|
### IPv4 地址
|
|
|
|
|
|
|
|
|
|
- **32 位二进制数**:IPv4 地址由 32 位二进制数字组成,通常分为四个 8 位的部分,每部分称为一个字节。
|
|
|
|
|
- **点分十进制表示法**:为了便于阅读,IPv4 地址通常以点分十进制格式表示,例如 `192.168.1.1`。每个字节的二进制数被转换成十进制数,并用点分隔。
|
|
|
|
|
- **网络部分和主机部分**:IPv4 地址分为网络部分和主机部分。网络部分标识特定的网络,而主机部分标识该网络上的特定设备。
|
|
|
|
|
|
|
|
|
|
| 组件 | 描述 | 例子 | 说明 |
|
|
|
|
|
| -------- | ---------------- | ----------------------------------- | ------------------------------- |
|
|
|
|
|
| 整体结构 | 32 位二进制数字 | 11000000.10101000.00000001.00000001 | 分为 4 个字节 |
|
|
|
|
|
| 表示法 | 点分十进制 | 192.168.1.1 | 每个字节转换为十进制,用点分隔 |
|
|
|
|
|
| 网络部分 | 标识特定网络 | 192.168.1 | 取决于类别(A, B, C)或子网掩码 |
|
|
|
|
|
| 主机部分 | 标识网络上的设备 | .1 | 剩余部分 |
|
|
|
|
|
|
|
|
|
|
### IPv6 地址
|
|
|
|
|
|
|
|
|
|
- **128 位二进制数**:IPv6 地址是由 128 位二进制数字组成,以解决 IPv4 地址空间不足的问题。
|
|
|
|
|
- **十六进制表示法**:IPv6 地址通常以 16 个字符的组(每组 4 个字符)表示,如 `2001:0db8:85a3:0000:0000:8a2e:0370:7334`。
|
|
|
|
|
- **更大的地址空间**:IPv6 提供了几乎无限的地址空间,支持更复杂的网络结构和更多的网络设备。
|
|
|
|
|
|
|
|
|
|
| 组件 | 描述 | 例子 | 说明 |
|
|
|
|
|
| -------- | ---------------- | --------------------------------------- | ---------------------- |
|
|
|
|
|
| 整体结构 | 128 位二进制数字 | 2001:0db8:85a3:0000:0000:8a2e:0370:7334 | 分为 8 组,每组 16 位 |
|
|
|
|
|
| 表示法 | 十六进制表示 | 2001:0db8:85a3:0000:0000:8a2e:0370:7334 | 每 16 位一组,用冒号分隔 |
|
|
|
|
|
| 网络部分 | 标识特定网络 | 2001:0db8:85a3 | 前缀长度不固定 |
|
|
|
|
|
| 主机部分 | 标识网络上的设备 | :0000:0000:8a2e:0370:7334 | 剩余部分 |
|
|
|
|
|
|
|
|
|
|
### 子网掩码
|
|
|
|
|
|
|
|
|
|
子网掩码用于区分 IP 地址的网络部分和主机部分。它对网络设计和管理至关重要。
|
|
|
|
|
|
|
|
|
|
#### 功能
|
|
|
|
|
|
|
|
|
|
- **划分网络**:子网掩码确定了 IP 地址中哪部分是网络地址,哪部分是主机地址。这对于 IP 地址的有效分配和网络流量的适当路由至关重要。
|
|
|
|
|
- **子网划分**:子网掩码允许网络管理员将大型网络划分为更小、更高效的子网。
|
|
|
|
|
|
|
|
|
|
#### 结构
|
|
|
|
|
|
|
|
|
|
- **二进制表示**:子网掩码是一串二进制数字,其中网络部分全为 1,主机部分全为 0。例如,255.255.255.0 的子网掩码在二进制中表示为 11111111.11111111.11111111.00000000。
|
|
|
|
|
- **CIDR 表示法**:在无类别域间路由(CIDR)中,子网掩码表示为斜线后跟数字,数字表示网络部分中的连续 1 的数量。例如,/24 表示前 24 位是网络地址,相当于 255.255.255.0。
|
|
|
|
|
|
|
|
|
|
| 组件 | 描述 | 例子 | 说明 |
|
|
|
|
|
| ---------- | ------------------------ | ----------------------------------- | -------------------------------------- |
|
|
|
|
|
| 整体结构 | 与 IP 地址同长度的二进制数 | 11111111.11111111.11111111.00000000 | 对应 IPv4 |
|
|
|
|
|
| 表示法 | 点分十进制 | 255.255.255.0 | 对应每 8 位二进制 |
|
|
|
|
|
| CIDR 表示法 | 斜线后跟数字 | /24 | 表示网络部分中的连续 1 的数量 |
|
|
|
|
|
| 功能 | 划分网络和主机部分 | - | 决定哪部分是网络地址,哪部分是主机地址 |
|
|
|
|
|
|
|
|
|
|
## IP 地址分配和管理
|
|
|
|
|
|
|
|
|
|
### 静态与动态 IP 地址
|
|
|
|
|
|
|
|
|
|
- **静态 IP 地址**:这是固定分配给网络设备的 IP 地址,一旦设置,除非管理员手动更改,否则不会变化。静态 IP 地址适用于服务器、打印机等需要固定 IP 以便轻易访问的设备。
|
|
|
|
|
- **动态 IP 地址**:动态 IP 地址由网络服务器自动分配,通常每次设备连接到网络时都可能更改。动态地址分配主要通过 DHCP 实现,适用于临时客户端设备,如员工的笔记本电脑。
|
|
|
|
|
|
|
|
|
|
### DHCP
|
|
|
|
|
|
|
|
|
|
- **动态主机配置协议(DHCP)**:这是一个网络管理协议,用于自动分配 IP 地址和其他相关配置信息给网络设备。DHCP 服务器在收到设备的请求时,从一个定义好的地址池中分配 IP 地址,并设置有效期(租期)。
|
|
|
|
|
- **工作原理**:当设备连接到网络时,它向网络广播一个 DHCP 请求。DHCP 服务器接收到请求后,从地址池中分配一个 IP 地址,并发送回应,包含 IP 地址、子网掩码、默认网关以及 DNS 服务器信息。
|
|
|
|
|
|
|
|
|
|
### IP 地址分配策略
|
|
|
|
|
|
|
|
|
|
#### 地址池管理
|
|
|
|
|
|
|
|
|
|
- **子网划分**:根据网络规模和需求,合理划分子网。小型网络可能只需要一个子网,而大型或分布广泛的网络可能需要多个子网。通过子网划分,可以更有效地管理IP地址。
|
|
|
|
|
- **地址池规模**:评估网络内部设备的数量,包括不仅限于工作站、服务器、打印机和无线设备等,预测未来扩展需要,确保地址池有足够的地址可以分配。
|
|
|
|
|
- **留白地址**:在地址池中预留一定数量的IP地址,用于未来扩展或临时需要。
|
|
|
|
|
|
|
|
|
|
#### 租期设置
|
|
|
|
|
|
|
|
|
|
- **动态地址分配租期**:针对普通客户端设备,可以设置较短的租期(例如24小时),以保证IP地址能够有效循环利用。租期过短可能会增加网络流量,而过长则可能导致IP地址浪费。
|
|
|
|
|
- **租期续订策略**:设定合理的续订策略,例如当租期过半时尝试续订,以减少因租期到期而导致的网络中断。
|
|
|
|
|
|
|
|
|
|
#### 保留地址
|
|
|
|
|
|
|
|
|
|
- **静态地址分配**:对于服务器、网络打印机、路由器等关键设备,分配静态IP地址。这样做可以确保这些设备的网络路径稳定可靠。
|
|
|
|
|
- **DHCP保留**:在DHCP服务器上为特定的MAC地址保留IP地址。即使是在使用动态地址分配的环境中,也可以确保某些特定设备总是获得相同的IP地址。
|
|
|
|
|
|
|
|
|
|
## 子网划分和超网
|
|
|
|
|
|
|
|
|
|
子网划分目的在于将大型网络划分成更小、更易管理的网络段。可以通过更改子网掩码将一个大型网络的 IP 地址空间划分成多个小网络。每个子网有自己的网络地址和广播地址,以及一系列可用于分配给设备的 IP 地址。
|
|
|
|
|
|
|
|
|
|
#### CIDR(无类别域间路由选择)
|
|
|
|
|
|
|
|
|
|
CIDR 是一种用于创建更灵活的网络地址分配方法的 IP 地址分配和路由选择方法。它允许更细粒度的子网划分,优化 IP 地址的使用。
|
|
|
|
|
|
|
|
|
|
- **实现方式**:CIDR 通过消除传统的 A、B、C 类网络划分,使用可变长度的子网掩码来定义网络。例如,一个 CIDR 地址如 192.168.100.14/24,其中“/24”指示网络部分占前 24 位。
|
|
|
|
|
- **应用**:CIDR 使得 IP 地址分配更加灵活,减少了 IP 地址的浪费,是互联网中广泛使用的技术。
|
|
|
|
|
|
|
|
|
|
## 路由和交换
|
|
|
|
|
|
|
|
|
|
### 路由原理
|
|
|
|
|
|
|
|
|
|
路由是指在网络中转发数据包从源头到目的地的过程。路由原理包括两种主要类型:**静态路由和动态路由。**
|
|
|
|
|
|
|
|
|
|
- **静态路由**:管理员手动配置路由表,指定网络中数据包的具体传输路径。适用于小型或稳定的网络环境,因为它不会自动适应网络变化。
|
|
|
|
|
- **动态路由**:路由器根据当前网络状态自动选择和调整路由路径。它通过使用各种路由协议来实现,适合大型或经常变化的网络。
|
|
|
|
|
|
|
|
|
|
### 动态路由协议
|
|
|
|
|
|
|
|
|
|
- **OSPF(开放最短路径优先)**:一种链路状态路由协议,通过构建网络的拓扑结构来确定数据包的最短路径。OSPF 可以快速适应网络的变化,适用于大型企业或机构网络。
|
|
|
|
|
- **BGP(边界网关协议)**:一种路径向量路由协议,主要用于互联网服务提供商(ISP)之间的路由决策。它能够处理大规模网络的复杂路由和策略。
|
|
|
|
|
|
|
|
|
|
### 交换技术
|
|
|
|
|
|
|
|
|
|
交换技术是在数据链路层对网络流量进行管理的技术,用于优化网络性能和提高效率。
|
|
|
|
|
|
|
|
|
|
- **网络分段**:通过使用交换机来分隔大型网络,从而降低了每个段内的数据拥塞,提高了网络的整体性能。
|
|
|
|
|
- **流量管理**:交换机根据 MAC 地址表来决定数据包的转发,从而减少了不必要的数据广播,提高了网络的效率。
|
|
|
|
|
|
|
|
|
|
### 路由器和交换机配置
|
|
|
|
|
|
|
|
|
|
- **基本配置步骤**:包括设置设备的 IP 地址、子网掩码、默认网关、路由协议和相关的安全配置,如访问控制列表(ACL)和网络地址转换(NAT)。
|
|
|
|
|
- **实践和模拟**:通过使用模拟软件(如 Cisco Packet Tracer 或 GNS3)或真实设备来进行实践操作,可以帮助理解和掌握复杂的网络配置和故障排除技巧。
|
|
|
|
|
|
|
|
|
|
## IP 协议的安全性
|
|
|
|
|
|
|
|
|
|
### 网络攻击类型
|
|
|
|
|
|
|
|
|
|
- **IP 欺骗**:黑客伪造 IP 地址以模拟另一台设备。这可能导致非授权访问,数据泄露或服务拒绝(DoS)攻击。
|
|
|
|
|
- **ARP 欺骗**:攻击者伪造地址解析协议(ARP)消息,欺骗网络中的设备,导致流量被错误地重定向或网络通信中断。
|
|
|
|
|
- **SYN 泛洪**:发送大量半开放的同步(SYN)请求,耗尽服务器资源,导致服务拒绝。
|
|
|
|
|
- **Man-in-the-Middle(MitM)攻击**:攻击者插入到通信双方之间,秘密拦截或篡改数据。
|
|
|
|
|
|
|
|
|
|
### 防火墙
|
|
|
|
|
|
|
|
|
|
- **基础概念**:网络安全系统,用于监控和控制进出网络的流量,基于一系列定义的安全规则。
|
|
|
|
|
- **配置方法**:定义安全规则来允许或阻止基于 IP 地址、端口号、协议类型等的特定流量。包括有状态和无状态过滤。
|
|
|
|
|
- **应用实例**:部署在网络边界,如网关,用于保护内部网络不受外部威胁。
|
|
|
|
|
|
|
|
|
|
### 访问控制列表(ACL)
|
|
|
|
|
|
|
|
|
|
- **功能**:定义哪些类型的流量可以进入或离开网络,用于增强网络安全和控制。
|
|
|
|
|
- **应用**:在路由器和交换机上配置 ACL,用于过滤流量,实现基于 IP、MAC 地址等的访问控制。
|
|
|
|
|
|
|
|
|
|
### VPN(虚拟私人网络)
|
|
|
|
|
|
|
|
|
|
- **概念**:通过公共网络(如互联网)创建加密的数据通信隧道,用于保护数据传输的隐私和安全。
|
|
|
|
|
- **配置和应用**:设置 VPN 协议(如 OpenVPN、IPSec),配合安全认证(如 SSL/TLS)实现。广泛应用于远程办公和跨地域网络连接。
|
|
|
|
|
|
|
|
|
|
## 故障排除和性能优化
|
|
|
|
|
|
|
|
|
|
### Windows 平台
|
|
|
|
|
|
|
|
|
|
#### 故障诊断工具
|
|
|
|
|
|
|
|
|
|
- **Ping**是用来测试网络连通性的,可以通过发送 ICMP (Internet Control Message Protocol) 回显请求给目标主机,并监听回显应答来检测网络连通性。
|
|
|
|
|
|
|
|
|
|
```cmd
|
|
|
|
|
ping google.com
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
- **Tracert** (Trace Route) 用于显示数据包到达目标主机所经过的路径。
|
|
|
|
|
|
|
|
|
|
```cmd
|
|
|
|
|
tracert google.com
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
- **IPConfig** 用于查看和刷新IP配置,如获取当前的 IP 地址、子网掩码、默认网关等。
|
|
|
|
|
|
|
|
|
|
```cmd
|
|
|
|
|
ipconfig /all
|
|
|
|
|
ipconfig /renew
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
- **Netstat**显示网络连接、路由表、接口统计信息等,常用于检查进出端口状态。
|
|
|
|
|
|
|
|
|
|
```cmd
|
|
|
|
|
netstat -an
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
- **Wireshark** 抓取和分析网络数据包。
|
|
|
|
|
|
|
|
|
|
- **Performance Monitor (PerfMon)** 监控系统和网络性能。
|
|
|
|
|
|
|
|
|
|
### Linux 平台
|
|
|
|
|
|
|
|
|
|
#### 故障诊断工具
|
|
|
|
|
|
|
|
|
|
- Linux 下的 **ping** 和 **traceroute** 与 Windows 下相似,用于测试网络连通性和显示数据包路径。
|
|
|
|
|
|
|
|
|
|
```shell
|
|
|
|
|
ping google.com
|
|
|
|
|
traceroute google.com
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
- **ip** 命令替代用于查看和配置网络接口。
|
|
|
|
|
|
|
|
|
|
```shell
|
|
|
|
|
ip addr show
|
|
|
|
|
ip link set dev eth0 up
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
- **ss** 是 **netstat** 的现代替代品,用于查看网络连接和端口状态。
|
|
|
|
|
|
|
|
|
|
```shell
|
|
|
|
|
ss -tulnp
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
- **Tcpdump**用于抓取网络数据包,类似于 Wireshark 但是在命令行下运行。
|
|
|
|
|
|
|
|
|
|
- **Nagios** 或 **Zabbix**是网络和系统监控工具,用于实时监控和生成性能报告。
|
|
|
|
|
|
|
|
|
|
## 持续学习与前沿技术
|
|
|
|
|
|
|
|
|
|
在网络工程领域,持续学习和关注前沿技术是非常重要的。这不仅有助于保持技能的现代性,还能确保在快速发展的技术环境中保持竞争力。下面深入探讨一些关键的前沿技术和行业动态。
|
|
|
|
|
|
|
|
|
|
### IPv6 的发展
|
|
|
|
|
|
|
|
|
|
IPv6 的推出主要是为了解决 IPv4 地址耗尽的问题,但它带来的好处远不止于此。
|
|
|
|
|
|
|
|
|
|
- **更大的地址空间**: IPv6 使用128位地址,理论上可以提供21282128个独立的网络地址,远远超过IPv4的232232个地址。这对于物联网(IoT)设备快速增长的时代尤为重要,每个设备都需要独立的网络地址。
|
|
|
|
|
- **改进的路由和自动配置特性**: IPv6 提高了路由的效率和灵活性。它支持直接自动配置,减少了网络设置的复杂性,使设备能够自动获得IP地址,简化了网络管理。
|
|
|
|
|
- **安全性增强**: IPv6 在设计之初就考虑到了安全问题,它原生支持IPsec,为数据传输提供加密和身份验证,而在IPv4中,这是一个可选项。
|
|
|
|
|
|
|
|
|
|
### SDN(软件定义网络)
|
|
|
|
|
|
|
|
|
|
SDN 是近年来网络技术领域的一大创新,它改变了传统网络架构的限制,提供了更高效和灵活的网络管理方法。
|
|
|
|
|
|
|
|
|
|
- **架构和应用**: SDN 的核心思想是将控制层从数据层分离,使网络管理变得更加集中和灵活。这一架构使网络管理员能够通过编程方式控制网络行为,而不是通过手动配置单个设备。
|
|
|
|
|
- **灵活的网络管理和自动化**: SDN 通过提供集中的网络控制功能,使得网络变更、优化和管理变得更加快捷和自动化。例如,网络流量可以根据实时需求自动重路由,以优化性能和资源使用。
|
|
|
|
|
|
|
|
|
|
### 行业动态
|
|
|
|
|
|
|
|
|
|
了解最新的行业动态对于网络工程师至关重要,以下是一些值得关注的领域:
|
|
|
|
|
|
|
|
|
|
- **5G**: 作为下一代移动通信标准,5G 不仅提高了数据传输速度,还大大减少了延迟,这对于实时应用如在线游戏、自动驾驶汽车和远程手术等领域将产生深远影响。
|
|
|
|
|
- **边缘计算**: 随着IoT设备的增多,数据产生的地点越来越靠近用户,边缘计算通过在数据产生地点附近进行数据处理,可以减少延迟,提高处理速度。
|
|
|
|
|
- **网络安全趋势**: 网络安全是一个持续演进的领域。了解最新的安全趋势,如使用机器学习和人工智能来预测和防御网络攻击,对于保护网络安全至关重要。
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|