元素码农
基础
UML建模
数据结构
算法
设计模式
网络
TCP/IP协议
HTTPS安全机制
WebSocket实时通信
数据库
sqlite
postgresql
clickhouse
后端
rust
go
java
php
mysql
redis
mongodb
etcd
nats
zincsearch
前端
浏览器
javascript
typescript
vue3
react
游戏
unity
unreal
C++
C#
Lua
App
android
ios
flutter
react-native
安全
Web安全
测试
软件测试
自动化测试 - Playwright
人工智能
Python
langChain
langGraph
运维
linux
docker
工具
git
svn
🌞
🌙
目录
▶
网络层
▶
IP协议
IP数据报格式
子网划分原理
CIDR无类寻址
IP分片与重组
IP选项字段
▶
ICMP协议
差错报文类型
Ping实现原理
Traceroute原理
▶
ARP协议
地址解析原理
ARP缓存表
代理ARP
▶
路由协议
RIP协议详解
OSPF协议原理
BGP协议机制
▶
IPv6协议
IPv6地址结构
IPv6报文格式
IPv6扩展头
IPv6过渡技术
▶
移动IP
移动IP原理
代理发现机制
注册与路由优化
▶
网络QoS
QoS服务模型
IntServ架构
DiffServ架构
MPLS技术
▶
NAT技术
NAT原理与类型
NAT穿透技术
NAT64与DNS64
▶
组播路由
组播基础
IGMP协议
PIM协议族
▶
网络安全
IPSec协议族
VPN技术详解
DDoS防护
▶
传输层
▶
TCP协议
三次握手机制
滑动窗口原理
拥塞控制算法
四次挥手过程
超时重传机制
TCP状态转换
快速重传机制
快速恢复算法
选择性确认SACK
时间戳选项
▶
UDP协议
数据报结构解析
实时传输优化
UDP校验和计算
UDP广播与多播
UDP性能调优
UDP可靠传输
▶
SCTP协议
SCTP协议概述
多宿主支持
多流传输
关联建立过程
心跳机制
▶
传输层安全
TLS协议详解
DTLS协议
密钥交换机制
证书验证
▶
应用层
▶
HTTP协议
请求响应模型
持久连接机制
HTTP消息格式
状态码详解
Cookie机制
HTTP缓存机制
HTTP认证机制
HTTPS详解
TLS/SSL协议
HTTP/1.0详解
HTTP/1.1详解
HTTP/2详解
HTTP/3详解
▶
DNS系统
域名解析过程
记录类型详解
递归与迭代查询
DNS缓存机制
▶
FTP协议
FTP工作原理
主动与被动模式
FTP命令详解
▶
SMTP协议
邮件传输流程
SMTP会话过程
邮件格式规范
▶
DHCP协议
DHCP工作原理
地址分配过程
DHCP中继代理
▶
SNMP协议
SNMP架构
MIB数据库
SNMP操作
SNMPv3安全机制
▶
WebSocket协议
WebSocket原理
握手升级机制
数据帧格式
心跳与连接维护
▶
QUIC协议
QUIC协议特性
0-RTT建连
多路复用
丢包恢复
▶
gRPC协议
gRPC基础
服务定义
通信模式
负载均衡
发布时间:
2025-03-21 20:55
↑
☰
# CIDR无类域间路由 ## 概述 CIDR(Classless Inter-Domain Routing,无类域间路由)是一种用于给IP地址分配和路由聚合的方法。它取代了传统的分类寻址方案,提供了更灵活和高效的IP地址分配机制。 ## CIDR的产生背景 ### 传统分类寻址的问题 1. 地址空间浪费 - A类网络过大(1600万个主机) - B类网络仍然较大(65534个主机) - C类网络过小(254个主机) 2. 路由表膨胀 - 每个网络都需要一个路由表项 - 互联网规模增长导致路由表急剧膨胀 ### CIDR的解决方案 1. 消除传统分类 - 不再有固定的A、B、C类划分 - 网络前缀长度可以是任意位数 2. 路由聚合 - 将多个路由条目聚合为一个 - 显著减少路由表大小 ## CIDR表示法 ### 基本格式 ```text IP地址/网络前缀长度 例如:192.168.100.0/24 ``` ### 表示规则 1. 斜线前为IP地址 2. 斜线后为网络前缀的位数(0-32) 3. 例如: - /24 表示前24位是网络号 - /16 表示前16位是网络号 ## 地址块划分 ### 基本原理 1. 可变长度的网络前缀 - 根据需求灵活分配地址块大小 - 避免地址空间浪费 2. 地址块大小计算 ```text 可用地址数 = 2^(32-前缀长度) - 2 ``` ### 划分示例 以192.168.0.0/16划分为多个/24网络: 1. 每个/24网络包含256个地址 2. 可以划分出256个/24网络: - 192.168.0.0/24 - 192.168.1.0/24 - ... - 192.168.255.0/24 ## 路由聚合 ### 聚合原理 1. 寻找共同前缀 - 多个连续的网络共享相同的高位比特 - 可以用一个更短的前缀表示 2. 聚合条件 - 地址块必须连续 - 地址块大小必须是2的幂 ### 聚合示例 四个连续的/24网络: ```text 192.168.1.0/24 192.168.2.0/24 192.168.3.0/24 192.168.4.0/24 ``` 可以聚合为: ```text 192.168.0.0/22 ``` ## 最长前缀匹配 ### 原理 1. 路由器在转发数据包时: - 查找路由表中所有匹配的条目 - 选择前缀最长的条目 2. 优点: - 提供更精确的路由 - 支持路由的层次化组织 ### 示例 路由表包含: ```text 192.168.0.0/16 192.168.1.0/24 ``` 目标地址192.168.1.1将匹配/24条目 ## CIDR的优势 ### 1. 地址分配灵活 - 可以根据实际需求分配地址块 - 避免地址空间浪费 - 支持细粒度的地址分配 ### 2. 路由效率提高 - 路由表大小显著减少 - 路由查找速度提升 - 网络设备内存需求降低 ### 3. 支持层次化寻址 - 便于实现地址的层次化管理 - 简化网络规划和管理 - 提高网络可扩展性 ## 实际应用 ### 1. ISP地址分配 - 根据客户需求分配地址块 - 实现地址的有效聚合 - 控制路由表规模 ### 2. 企业网络规划 - 灵活的子网划分 - 预留地址空间 - 支持未来扩展 ### 3. 数据中心网络 - 高效的地址分配 - 简化路由配置 - 优化网络性能 ## 最佳实践 ### 1. 地址规划 - 预留足够的地址空间 - 考虑未来扩展需求 - 保持地址块连续性 ### 2. 路由优化 - 合理使用路由聚合 - 控制路由表大小 - 避免过度聚合 ### 3. 文档管理 - 记录地址分配方案 - 维护路由配置文档 - 定期审查和更新 ## 常见问题 ### 1. 地址重叠 解决方法: - 仔细规划地址分配 - 避免随意分配地址块 - 定期检查地址使用情况 ### 2. 路由黑洞 预防措施: - 谨慎进行路由聚合 - 确保所有子网可达 - 配置适当的默认路由 ### 3. 扩展性问题 解决方案: - 预留充足的地址空间 - 采用模块化的网络设计 - 定期评估和调整 ## 总结 CIDR作为现代IP地址分配和路由技术的基础,具有以下优点: 1. 提高地址利用率 - 灵活的地址分配 - 避免地址浪费 2. 优化路由效率 - 支持路由聚合 - 减少路由表大小 3. 增强网络可扩展性 - 层次化地址结构 - 简化网络管理 在实际应用中,网络管理员需要: - 深入理解CIDR原理 - 合理规划地址分配 - 优化路由配置 - 注重长期可维护性