TCP/IP 详解(第二版) 笔记 / 目录

35 篇文章 0 订阅

1 介绍

1.1 架构原则

1.2 设计与实现

1.3 TCP/IP 协议栈的架构与协议

1.4 互联网, 内联网, 外联网

1.5 设计应用程序

1.6 标准化过程

1.7 实现与软件分发

1.8 涉及互联网架构的攻击

1.9 总结

1.10 参考文献

2 互联网地址架构

2.1 介绍

2.2 IP 地址表示

2.3 基本的 IP 地址结构

2.4 CIDR 与聚合

2.5 有特殊用途的地址

2.6 分配

  • 2.6.1 单播
  • 2.6.2 组播

2.7 单播地址分配

  • 2.7.1 Single Provider/No Network/Single Address
  • 2.7.2 Single Provider/Single Network/Single Address
  • 2.7.3 Single Provider/Multiple Networks/Multiple Addresses
  • 2.7.4 Multiple Providers/Multiple Networks/Multiple Addresses (Multihoming)

2.8 涉及 IP 地址的攻击

2.9 总结

2.10 参考文献

3 链路层

3.1 介绍

3.2 以太网与 IEEE 802 LAN_MAN 标准

  • 3.2.1 IEEE 802 LAN/MAN 标准
  • 3.2.2 以太网框架格式
  • 3.2.3 802.1p/q:Virtual LANs and QoS Tagging
  • 3.2.4 802.1AX:链路聚合 (Formerly 802.3ad)

3.3 全双工, 节能, 自动协商机制, 802.1X 流控制

  • 3.3.1 双工不匹配
  • 3.3.2 Wake-on LAN (WoL), 节能, Magic Packets
  • 3.3.3 链路层流程控制

3.4 桥接器与交换机

  • 3.4.1 生成树协议(Spanning Tree Protocol (STP))
  • 3.4.2 802.1ak:Multiple Registration Protocol (MRP)

3.5 无线局域网 - IEEE 802.11 (Wi-Fi)

  • 3.5.1 802.11 框架
  • 3.5.2 节能模式与 Time Sync Function (TSF)
  • 3.5.3 802.11 介质访问控制
  • 3.5.4 物理层细节:Rates, Channels, Frequencies
  • 3.5.5 Wi-Fi 安全
  • 3.5.6 Wi-Fi 网格 (802.11s)

3.6 点对点协议(Point-to-Point Protocol (PPP))

  • 3.6.1 链路控制协议(Link Control Protocol (LCP))
  • 3.6.2 多链路点对点协议(Multilink PPP (MP))
  • 3.6.3 压缩控制协议(Compression Control Protocol (CCP))
  • 3.6.4 PPP 鉴权
  • 3.6.5 网络控制协议(Network Control Protocols (NCPs))
  • 3.6.6 Header 压缩
  • 3.6.7 例子

3.7 回环

3.8 MTU 与 Path MTU

3.9 隧道基础知识

  • 3.9.1 单向链路

3.10 链路层上的攻击

3.11 总结

3.12 参考文献

4 地址解析协议(Address Resolution Protocol (ARP))

4.1 介绍

4.2 例子

  • 4.2.1 直接交付与 ARP

4.3 ARP 缓存

4.4 ARP 框架格式

4.5 ARP 例子

  • 4.5.1 普通例子
  • 4.5.2 到不存在的主机的 ARP 请求

4.6 ARP 缓存超时

4.7 代理 ARP

4.8 免费 ARP 与地址冲突检测(Address Conflict Detection (ACD))

4.9 arp 命令

4.10 使用 ARP 为一个内置设备设置 IPv4 地址

4.11 涉及 ARP 的攻击

4.12 总结

4.13 参考文献

5 IP 协议

5.1 介绍

5.2 IPv4 与 IPv6 Header

  • 5.2.1 IP Header 字段
  • 5.2.2 互联网校验和
  • 5.2.3 DS 字段与 ECN (以前叫做 ToS Byte 或 IPv6 流量类型)
  • 5.2.4 IP 选项

5.3 IPv6 扩展 Header

  • 5.3.1 IPv6 选项
  • 5.3.2 路由 Header
  • 5.3.3 分片 Header

5.4 IP 转发

  • 5.4.1 转发表
  • 5.4.2 IP 转发操作
  • 5.4.3 例子
  • 5.4.4 讨论

5.5 移动 IP

  • 5.5.1 基本模型:双向隧道
  • 5.5.2 路由优化(Route Optimization (RO))
  • 5.5.3 讨论

5.6 主机对 IP 数据报的处理

  • 5.6.1 主机模型
  • 5.6.2 地址选择

5.7 涉及 IP 的攻击

5.8 总结

5.9 参考文献

6 系统配置:DHCP 和自动配置

6.1 介绍

6.2 动态主机配置协议(Dynamic Host Configuration Protocol (DHCP))

  • 6.2.1 地址池与租约
  • 6.2.2 DHCP 与 BOOTP 报文格式
  • 6.2.3 DHCP 与 BOOTP 选项
  • 6.2.4 DHCP 协议操作
  • 6.2.5 DHCPv6
  • 6.2.6 在有中继的情况下使用 DHCP
  • 6.2.7 DHCP 鉴权
  • 6.2.8 重新配置扩展
  • 6.2.9 快速提交
  • 6.2.10 位置信息(Location Information (LCI and LoST))
  • 6.2.11 Mobility and Handoff Information (MoS and ANDSF)
  • 6.2.12 DHCP 窥探

6.3 无状态地址自动配置(Stateless Address Autoconfiguration (SLAAC))

  • 6.3.1 动态配置 IPv4 链路本地地址
  • 6.3.2 为链路本地地址做 IPv6 SLAAC

6.4 DHCP 与 DNS 交互

6.5 以太网上的 PPP(PPP over Ethernet (PPPoE))

6.6 涉及系统配置的攻击

6.7 总结

6.8 参考文献

7 防火墙与网络地址转换(Network Address Translation (NAT))

7.1 介绍

7.2 防火墙

  • 7.2.1 包过滤防火墙
  • 7.2.2 代理防火墙

7.3 网络地址转换(Network Address Translation (NAT))

  • 7.3.1 传统的 NAT:基本 NAT 与 NAPT
  • 7.3.2 地址与端口翻译行为
  • 7.3.3 过滤器行为
  • 7.3.4 NATs 背后的服务器
  • 7.3.5 发夹与 NAT 回环
  • 7.3.6 NAT 编辑器
  • 7.3.7 服务供应商 NAT(Service Provider NAT (SPNAT))与服务供应商 IPv6 翻译

7.4 NAT 穿透

  • 7.4.1 针孔与打洞
  • 7.4.2 单边自我绑定地址(UNilateral Self-Address Fixing (UNSAF))
  • 7.4.3 NAT 会话穿透工具(Session Traversal Utilities for NAT (STUN))
  • 7.4.4 NAT 中继穿透(Traversal Using Relays around NAT (TURN))
  • 7.4.5 交互式连接建立(Interactive Connectivity Establishment (ICE))

7.5 配置包过滤防火墙与 NAT

  • 7.5.1 防火墙规则
  • 7.5.2 NAT 规则
  • 7.5.3 与 NAT 和防火墙直接交互:UPnP, NAT-PMP, PCP

7.6 实现 IPv4 与 IPv6 共存与转换的 NAT

  • 7.6.1 轻型双协议栈(Dual-Stack Lite (DS-Lite))
  • 7.6.2 用 NAT 与 ALG 进行 IPv4 IPv6 翻译

7.7 涉及防火墙与 NAT 的攻击

7.8 总结

7.9 参考文献

8 ICMPv4 和 ICMPv6:互联网控制报文协议(Internet Control Message Protocol)

8.1 介绍

  • 8.1.1 IPv4 与 IPv6 中的封装

8.2 ICMP 报文

  • 8.2.1 ICMPv4 报文
  • 8.2.2 ICMPv6 报文
  • 8.2.3 ICMP 报文的处理

8.3 ICMP 错误报文

  • 8.3.1 扩展的 ICMP 与多部分报文
  • 8.3.2 无法到达目的地 (ICMPv4 Type 3, ICMPv6 Type 1) 与包太大 (ICMPv6 Type 2)
  • 8.3.3 重定向 (ICMPv4 Type 5, ICMPv6 Type 137)
  • 8.3.4 ICMP 超时 (ICMPv4 Type 11, ICMPv6 Type 3)
  • 8.3.5 参数问题 (ICMPv4 Type 12, ICMPv6 Type

8.4 ICMP 请求/有信息的报文

  • 8.4.1 回显请求/回复 (ping) (ICMPv4 Types 0/8, ICMPv6 Types 129/128)
  • 8.4.2 路由器发现:路由器请求与公告 (ICMPv4 Types 9, 10)
  • 8.4.3 本地代理地址发现请求/回复 (ICMPv6 Types 144/145)
  • 8.4.4 移动前缀请求/公告 (ICMPv6 Types 146/147)
  • 8.4.5 移动 IPv6 快速切换报文 (ICMPv6 Type 154)
  • 8.4.6 组播侦听者请求/报告/完成 (ICMPv6 Types 130/131/132)
  • 8.4.7 组播侦听者发现版本 2(Version 2 Multicast Listener Discovery (MLDv2))(ICMPv6 Type 143)
  • 8.4.8 组播路由器发现(Multicast Router Discovery (MRD))(IGMP Types 48/49/50, ICMPv6 Types 151/152/153)

8.5 IPv6 中的邻居发现

  • 8.5.1 ICMPv6 路由器请求与公告 (ICMPv6 Types 133, 134)
  • 8.5.2 ICMPv6 令居请求与公告 (ICMPv6 Types 135, 134)
  • 8.5.3 ICMPv6 反向邻居发现请求/公告 (ICMPv6 Types 141/142)
  • 8.5.4 邻居状态检测(Neighbor Unreachablility Detection (NUD))
  • 8.5.5 安全邻居发现(Secure Neighbor Discovery (SEND))
  • 8.5.6 ICMPv6 邻居发现(Neighbor Discovery (ND))选项

8.6 翻译 ICMPv4 与 ICMPv6

  • 8.6.1 将 ICMPv4 翻译为 ICMPv6
  • 8.6.2 将 ICMPv6 翻译为 ICMPv4

8.7 涉及 ICMP 的攻击

8.8 总结

8.9 参考手册

9 广播与本地组播 (IGMP 与 MLD)

9.1 介绍

9.2 广播

  • 9.2.1 使用广播地址
  • 9.2.2 发送广播数据报

9.3 组播

  • 9.3.1 将 IP 组播地址转换为 802 MAC/以太网地址
  • 9.3.2 例子
  • 9.3.3 发送组播数据报
  • 9.3.4 接收组播数据报
  • 9.3.5 主机地址过滤器

9.4 互联网组管理协议(Internet Group Management Protocol (IGMP))与组播侦听者发现协议(Multicast Listener Discovery Protocol (MLD))

  • 9.4.1 IGMP 与组成员处理 MLD (“组成员部分”)
  • 9.4.2 IGMP 与组播路由器处理 MLD (“组播路由器部分”)
  • 9.4.3 例子
  • 9.4.4 轻量级 IGMPv3 与 MLDv2
  • 9.4.5 IGMP 与 MLD 健壮性
  • 9.4.6 IGMP 与 MLD 计数器与变量
  • 9.4.7 IGMP 与 MLD 窥探

9.5 涉及 IGMP 与 MLD 的攻击

9.6 总结

9.7 参考文献

10 用户数据报协议(User Datagram Protocol (UDP))和 IP 分片

10.1 介绍

10.2 UDP Header

10.3 UDP 校验和

10.4 例子

10.5 UDP 与 IPv6

  • 10.5.1 Teredo:通过 IPv4 网络建立 IPv6 隧道

10.6 轻量级 UDP(UDP-Lite)

10.7 IP 分片

  • 10.7.1 例子:UDP/IPv4 分片
  • 10.7.2 重组超时

10.8 UDP 的 Path MTU 发现

  • 10.8.1 例子

10.9 IP 分片与 ARP/ND 交互

10.10 UDP 数据报的最大长度

  • 10.10.1 实现限制
  • 10.10.2 数据报截断

10.11 UDP 服务器设计

  • 10.11.1 IP 地址与 UDP 端口号
  • 10.11.2 限制本地 IP 地址
  • 10.11.3 使用多个地址
  • 10.11.4 限制外部 IP 地址
  • 10.11.5 每个端口使用多个服务器
  • 10.11.6 Spanning Address Families:IPv4 与 IPv6
  • 10.11.7 流量不够用与拥塞控制

10.12 翻译 UDP/IPv4 与 UDP/IPv6 数据报

10.13 互联网中的 UDP

10.14 设计 UDP 与 IP 分片的攻击

10.15 总结

10.16 参考文献

11 域名解析与域名系统(Domain Name System (DNS))

11.1 介绍

11.2 DNS 命名空间

  • 11.2.1 DNS 命名语法

11.3 域名服务器与区域

11.4 缓存

11.5 DNS 协议

  • 11.5.1 DNS 报文格式
  • 11.5.2 DNS 扩展格式(The DNS Extension Format (EDNS0))
  • 11.5.3 UDP 或 TCP
  • 11.5.4 Question (Query) 与区域部分格式
  • 11.5.5 回答, 授权, 额外信息部分格式
  • 11.5.6 资源记录类型
  • 11.5.7 动态更新 (DNS UPDATE)
  • 11.5.8 区域翻译与 DNS NOTIFY

11.6 Sort Lists, Round-Robin, Split DNS

11.7 Open DNS 服务器与 DynDNS

11.8 透明度与扩展性

11.9 将 IPv4 翻译为 IPv6 的 DNS (DNS64)

11.10 LLMNR 与 mDNS

11.11 LDAP

11.12 DNS 上的攻击

11.13 总结

11.14 参考文献

12 TCP:传输控制协议(Transmission Control Protocol (Preliminaries))

12.1 介绍

  • 12.1.1 ARQ 与重发
  • 12.1.2 数据包窗口与滑动窗口
  • 12.1.3 变量窗口:流程控制与拥塞控制
  • 12.1.4 设置重发超时

12.2 TCP 介绍

  • 12.2.1 TCP 服务模型
  • 12.2.2 TCP 可靠性

12.3 TCP Header 与封装

12.4 总结

12.5 参考文献

13 TCP 连接管理

13.1 介绍

13.2 TCP 连接建立与终止

  • 13.2.1 TCP 半关闭
  • 13.2.2 同时打开与关闭
  • 13.2.3 初始序列号(Initial Sequence Number (ISN))
  • 13.2.4 例子
  • 13.2.5 连接建立超时
  • 13.2.6 连接与翻译器

13.3 TCP 选项

  • 13.3.1 最大报文段长度(Maximum Segment Size (MSS))选项
  • 13.3.2 选择性确认(Selective Acknowledgment (SACK))选项
  • 13.3.3 Window Scale (WSCALE 或 WSOPT) 选项
  • 13.3.4 时间戳选项与防止序号回绕(Protection against Wrapped Sequence Numbers (PAWS))
  • 13.3.5 用户超时(User Timeout (UTO))选项
  • 13.3.6 鉴权选项(Authentication Option (TCP-AO))

13.4 TCP 的 Path MTU 发现

  • 13.4.1 例子

13.5 TCP 状态转换

  • 13.5.1 TCP 状态转换图
  • 13.5.2 TIME_WAIT (2MSL Wait) 状态
  • 13.5.3 安静时间
  • 13.5.4 FIN_WAIT_2 状态
  • 13.5.5 开关同时转换

13.6 重置段

  • 13.6.1 向不存在的端口请求连接
  • 13.6.2 中止连接
  • 13.6.3 半开的连接
  • 13.6.4 TIME-WAIT 暗杀(TIME-WAIT Assassination (TWA))

13.7 TCP 服务器操作

  • 13.7.1 TCP 端口号
  • 13.7.2 限制本地 IP 地址
  • 13.7.3 限制外部端点
  • 13.7.4 呼入连接队列

13.8 涉及 TCP 连接管理的攻击

13.9 总结

13.10 参考文献

14 TCP 超时与重传

14.1 介绍

14.2 简单的超时与重传例子

14.3 设置重传超时(Retransmission Timeout (RTO))

  • 14.3.1 经典方法
  • 14.3.2 标准方法
  • 14.3.3 Linux 方法
  • 14.3.4 RTT 估计器行为
  • 14.3.5 RTTM 健壮性降低与重排序

14.4 基于定时器的重传

  • 14.4.1 例子

14.5 快速重传

  • 14.5.1 例子

14.6 用选择性确认进行重传

  • 14.6.1 SACK 接受者行为
  • 14.6.2 SACK 发送者行为
  • 14.6.3 例子

14.7 假超时与重传

  • 14.7.1 复制 SACK(Duplicate SACK (DSACK))扩展
  • 14.7.2 Eifel 检测算法
  • 14.7.3 Forward-RTO 恢复 (F-RTO)
  • 14.7.4 Eifel 响应算法

14.8 数据包重排序与复制

  • 14.8.1 重排序
  • 14.8.2 复制

14.9 目的地度量

14.10 重新打包

14.11 涉及 TCP 重传的攻击

14.12 总结

14.13 参考文献

15 TCP 数据流与窗口管理

15.1 介绍

15.2 交互式通信

15.3 延迟确认

15.4 Nagle 算法

  • 15.4.1 延迟 ACK 与 Nagle 算法交互
  • 15.4.2 禁用 Nagle 算法

15.5 流程控制与窗口管理

  • 15.5.1 滑动窗口
  • 15.5.2 零窗口与 TCP 坚持定时器
  • 15.5.3 糊涂窗口综合征(Silly Window Syndrome (SWS))
  • 15.5.4 大缓冲区与自动调谐

15.6 应急机制

  • 15.6.1 例子

15.7 与窗口管理相关的攻击

15.8 总结

15.9 参考文献

16 TCP 拥塞控制

16.1 介绍

  • 16.1.1 TCP 中的拥塞检测
  • 16.1.2 减慢 TCP 发送者

16.2 经典算法

  • 16.2.1 慢启动
  • 16.2.2 拥塞避免
  • 16.2.3 在慢启动与拥塞避免之间做选择
  • 16.2.4 Tahoe, Reno, 快速恢复
  • 16.2.5 标准 TCP

16.3 标准算法的演变

  • 16.3.1 NewReno
  • 16.3.2 用 SACK 进行 TCP 拥塞控制
  • 16.3.3 转发确认(Forward Acknowledgment (FACK))与比率等分
  • 16.3.4 有限传输
  • 16.3.5 拥塞窗口验证(Congestion Window Validation (CWV))

16.4 处理假 RTO - Eifel 响应算法

16.5 扩展的例子

  • 16.5.1 慢启动行为
  • 16.5.2 发送者暂停与本地拥塞 (Event 1)
  • 16.5.3 Stretch ACKs 与从本地拥塞中恢复
  • 16.5.4 快速重传与 SACK 恢复 (Event 2)
  • 16.5.5 额外本地拥塞与快速重传事件
  • 16.5.6 超时, 重传, Undoing cwnd Changes
  • 16.5.7 连接完成

16.6 共享拥塞状态

16.7 TCP 友好

16.8 高速环境中的 TCP

  • 16.8.1 高速 TCP(HighSpeed TCP (HSTCP))与有限慢启动
  • 16.8.2 二进制增长拥塞控制(Binary Increase Congestion Control (BIC 与 CUBIC))

16.9 基于延迟的拥塞控制

  • 16.9.1 Vegas
  • 16.9.2 FAST
  • 16.9.3 TCP Westwood and Westwood+
  • 16.9.4 复合 TCP

16.10 缓冲区膨胀

16.11 主动队列管理与 ECN

16.12 涉及 TCP 拥塞控制的攻击

16.13 总结

16.14 参考文献

17 TCP Keepalive

17.1 介绍

17.2 描述

  • 17.2.1 Keepalive 例子

17.3 涉及 TCP Keepalive 的攻击

17.4 总结

17.5 参考文献

18 安全:EAP, IPsec, TLS, DNSSEC, DKIM

18.1 介绍

18.2 信息安全的基本原则

18.3 对网络通信的威胁

18.4 基本加密与安全机制

  • 18.4.1 密码系统
  • 18.4.2 Rivest, Shamir, Adleman (RSA) 公钥加密
  • 18.4.3 Diffie-Hellman-Merkle Key Agreement (aka Diffie-Hellman 或 DH)
  • 18.4.4 签密与 Elliptic Curve Cryptography (ECC)
  • 18.4.5 密钥导出与完全正向保密(Perfect Forward Secrecy (PFS))
  • 18.4.6 伪随机数, 生成器, 函数族
  • 18.4.7 随机数与加盐
  • 18.4.8 加密哈希函数与消息摘要
  • 18.4.9 消息认证码(Message Authentication Codes (MACs, HMAC, CMAC, GMAC))
  • 18.4.10 Cryptographic Suites 与 Cipher Suites

18.5 证书, 证书授权中心(Certificate Authorities (CAs)), PKIs

  • 18.5.1 公钥证书, 证书授权中心, X.509
  • 18.5.2 验证证书有效性与撤回证书
  • 18.5.3 属性证书

18.6 TCP/IP 安全协议与分层

18.7 网络访问控制:802.1X, 802.1AE, EAP, PANA

  • 18.7.1 EAP 方法与密钥导出
  • 18.7.2 EAP 重新认证协议(EAP Re-authentication Protocol (ERP))
  • 18.7.3 承载网络访问认证的协议(Protocol for Carrying Authentication for Network Access (PANA))

18.8 3 层 IP 安全(IP Security (IPsec))

  • 18.8.1 互联网密钥交换(Internet Key Exchange (IKEv2))协议
  • 18.8.2 Authentication Header (AH)
  • 18.8.3 封装安全载荷(Encapsulating Security Payload (ESP))
  • 18.8.4 组播
  • 18.8.5 L2TP/IPsec
  • 18.8.6 IPsec NAT 穿越
  • 18.8.7 例子

18.9 传输层安全(Transport Layer Security (TLS 与 DTLS))

  • 18.9.1 TLS 1.2
  • 18.9.2 数据报 TLS(TLS with Datagrams (DTLS))

18.10 DNS 安全(DNS Security (DNSSEC))

  • 18.10.1 DNSSEC 资源记录
  • 18.10.2 DNSSEC 操作
  • 18.10.3 事务鉴权 (TSIG, TKEY, SIG(0))
  • 18.10.4 DNS64 的 DNSSEC

18.11 域名密钥识别邮件(DomainKeys Identified Mail (DKIM))

  • 18.11.1 DKIM 签密
  • 18.11.2 例子

18.12 安全协议上的攻击

18.13 总结

18.14 参考文献

  • 0
    点赞
  • 1
    评论
  • 0
    收藏
  • 一键三连
    一键三连
  • 扫一扫,分享海报

tcp ip详解2全部实现 目 录 译者序 前言 第1章 概述 1 1.1 引言 1 1.2 源代码表示 1 1.2.1 将拥塞窗口设置为1 1 1.2.2 印刷约定 2 1.3 历史 2 1.4 应用编程接口 3 1.5 程序示例 4 1.6 系统调用和库函数 6 1.7 网络实现概述 6 1.8 描述符 7 1.9 mbuf与输出处理 11 1.9.1 包含插口地址结构的mbuf 11 1.9.2 包含数据的mbuf 12 1.9.3 添加IP和UDP首部 13 1.9.4 IP输出 14 1.9.5 以太网输出 14 1.9.6 UDP输出小结 14 1.10 输入处理 15 1.10.1 以太网输入 15 1.10.2 IP输入 15 1.10.3 UDP输入 16 1.10.4 进程输入 17 1.11 网络实现概述(续) 17 1.12 中断级别与并发 18 1.13 源代码组织 20 1.14 测试网络 21 1.15 小结 22 第2章 mbuf:存储器缓存 24 2.1 引言 24 2.2 代码介绍 27 2.2.1 全局变量 27 2.2.2 统计 28 2.2.3 内核统计 28 2.3 mbuf的定义 29 2.4 mbuf结构 29 2.5 简单的mbuf宏和函数 31 2.5.1 m_get函数 32 2.5.2 MGET宏 32 2.5.3 m_retry函数 33 2.5.4 mbuf锁 34 2.6 m_devget和m_pullup函数 34 2.6.1 m_devget函数 34 2.6.2 mtod和dtom宏 36 2.6.3 m_pullup函数和连续的协议首部 36 2.6.4 m_pullup和IP的分片与重组 37 2.6.5 TCP重组避免调用m_pullup 39 2.6.6 m_pullup使用总结 40 2.7 mbuf宏和函数的小结 40 2.8 Net/3联网数据结构小结 42 2.9 m_copy和簇引用计数 43 2.10 其他选择 47 2.11 小结 47 第3章 接口层 49 3.1 引言 49 3.2 代码介绍 49 3.2.1 全局变量 49 3.2.2 SNMP变量 50 3.3 ifnet结构 51 3.4 ifaddr结构 57 3.5 sockaddr结构 58 3.6 ifnet与ifaddr的专用化 59 3.7 网络初始化概述 60 3.8 以太网初始化 61 3.9 SLIP初始化 64 3.10 环回初始化 65 3.11 if_attach函数 66 3.12 ifinit函数 72 3.13 小结 73 第4章 接口:以太网 74 4.1 引言 74 4.2 代码介绍 75 4.2.1 全局变量 75 4.2.2 统计量 75 4.2.3 SNMP变量 76 4.3 以太网接口 77 4.3.1 leintr函数 79 4.3.2 leread函数 79 4.3.3 ether_input函数 81 4.3.4 ether_output函数 84 4.3.5 lestart函数 87 4.4 ioctl系统调用 89 4.4.1 ifioctl函数 90 4.4.2 ifconf函数 91 4.4.3 举例 94 4.4.4 通用接口ioctl命令 95 4.4.5 if_down和if_up函数 96 4.4.6 以太网、SLIP和环回 97 4.5 小结 98 第5章 接口:SLIP和环回 100 5.1 引言 100 5.2 代码介绍 100 5.2.1 全局变量 100 5.2.2 统计量 101 5.3 SLIP接口 101 5.3.1 SLIP线路规程:SLIPDISC 101 5.3.2 SLIP初始化:slopen和slinit 103 5.3.3 SLIP输入处理:slinput 105 5.3.4 SLIP输出处理:sloutput 109 5.3.5 slstart函数 111 5.3.6 SLIP分组丢失 116 5.3.7 SLIP性能考虑 117 5.3.8 slclose函数 117 5.3.9 sltioctl函数 118 5.4 环回接口 119 5.5 小结 121 第6章 IP编址 123 6.1 引言 123 6.1.1 IP地址 123 6.1.2 IP地址的印刷规定 123 6.1.3 主机和路由器 124 6.2 代码介绍 125 6.3 接口和地址小结 125 6.4 sockaddr_in结构 126 6.5 in_ifaddr结构 127 6.6 地址指派 128 6.6.1 ifioctl函数 130 6.6.2 in_control函数 130 6.6.3 前提条件:SIOCSIFADDR、 SIOCSIFNETMASK和 SIOCSIFDSTADDR 132 6.6.4 地址指派:SIOCSIFADDR 133 6.6.5 in_ifinit函数 133 6.6.6 网络掩码指派:SIOCSIFNETMASK 136 6.6.7 目的地址指派:SIOCSIFDSTADDR 137 6.6.8 获取接口信息 137 6.6.9 每个接口多个IP地址 138 6.6.10 附加IP地址:SIOCAIFADDR 139 6.6.11 删除IP地址:SIOCDIFADDR 140 6.7 接口ioctl处理 141 6.7.1 leioctl函数 141 6.7.2 slioctl函数 142 6.7.3 loioctl函数 143 6.8 Internet实用函数 144 6.9 ifnet实用函数 144 6.10 小结 145 第7章 域和协议 146 7.1 引言 146 7.2 代码介绍 146 7.2.1 全局变量 147 7.2.2 统计量 147 7.3 domain结构 147 7.4 protosw结构 148 7.5 IP 的domain和protosw结构 150 7.6 pffindproto和pffindtype函数 155 7.7 pfctlinput函数 157 7.8 IP初始化 157 7.8.1 Internet传输分用 157 7.8.2 ip_init函数 158 7.9 sysctl系统调用 159 7.10 小结 161 第8章 IP:网际协议 162 8.1 引言 162 8.2 代码介绍 163 8.2.1 全局变量 163 8.2.2 统计量 163 8.2.3 SNMP变量 164 8.3 IP分组 165 8.4 输入处理:ipintr函数 167 8.4.1 ipintr概观 167 8.4.2 验证 168 8.4.3 转发或不转发 171 8.4.4 重装和分用 173 8.5 转发:ip_forward函数 174 8.6 输出处理:ip_output函数 180 8.6.1 首部初始化 181 8.6.2 路由选择 182 8.6.3 源地址选择和分片 184 8.7 Internet检验和:in_cksum函数 186 8.8 setsockopt和getsockopt系统调用 190 8.8.1 PRCO_SETOPT的处理 192 8.8.2 PRCO_GETOPT的处理 193 8.9 ip_sysctl函数 193 8.10 小结 194 第9章 IP选项处理 196 9.1 引言 196 9.2 代码介绍 196 9.2.1 全局变量 196 9.2.2 统计量 197 9.3 选项格式 197 9.4 ip_dooptions函数 198 9.5 记录路由选项 200 9.6 源站和记录路由选项 202 9.6.1 save_rte函数 205 9.6.2 ip_srcroute函数 206 9.7 时间戳选项 207 9.8 ip_insertoptions函数 210 9.9 ip_pcbopts函数 214 9.10 一些限制 217 9.11 小结 217 第10章 IP的分片与重装 218 10.1 引言 218 10.2 代码介绍 219 10.2.1 全局变量 220 10.2.2 统计量 220 10.3 分片 220 10.4 ip_optcopy函数 223 10.5 重装 224 10.6 ip_reass函数 227 10.7 ip_slowtimo函数 237 10.8 小结 238 第11章 ICMP:Internet控制报文协议 239 11.1 引言 239 11.2 代码介绍 242 11.2.1 全局变量 242 11.2.2 统计量 242 11.2.3 SNMP变量 243 11.3 icmp结构 244 11.4 ICMP 的protosw结构 245 11.5 输入处理:icmp_input函数 246 11.6 差错处理 249 11.7 请求处理 251 11.7.1 回显询问:ICMP_ECHO和 ICMP_ECHOREPLY 252 11.7.2 时间戳询问:ICMP_TSTAMP和 ICMP_TSTAMPREPLY 253 11.7.3 地址掩码询问:ICMP_MASKREQ和 ICMP_MASKREPLY 253 11.7.4 信息询问:ICMP_IREQ和ICMP_ IREQREPLY 255 11.7.5 路由器发现:ICMP_ROUTERADVERT 和ICMP_ROUTERSOLICIT 255 11.8 重定向处理 255 11.9 回答处理 257 11.10 输出处理 257 11.11 icmp_error函数 258 11.12 icmp_reflect函数 261 11.13 icmp_send函数 265 11.14 icmp_sysctl函数 266 11.15 小结 266 第12章 IP多播 268 12.1 引言 268 12.2 代码介绍 269 12.2.1 全局变量 270 12.2.2 统计量 270 12.3 以太网多播地址 270 12.4 ether_multi结构 271 12.5 以太网多播接收 273 12.6 in_multi结构 273 12.7 ip_moptions结构 275 12.8 多播的插口选项 276 12.9 多播的TTL值 277 12.9.1 MBONE 278 12.9.2 扩展环搜索 278 12.10 ip_setmoptions函数 278 12.10.1 选择一个明确的多播接口:IP_ MULTICAST_IF 280 12.10.2 选择明确的多播TTL: IP_ MULTICAST_TTL 281 12.10.3 选择多播环回:IP_MULTICAST_ LOOP 281 12.11 加入一个IP多播组 282 12.11.1 in_addmulti函数 285 12.11.2 slioctl和loioctl函数:SIOCADDMULTI和SIOCDELMULTI 287 12.11.3 leioctl函数:SIOCADDMULTI和 SIOCDELMULTI 288 12.11.4 ether_addmulti函数 288 12.12 离开一个IP多播组 291 12.12.1 in_delmulti函数 292 12.12.2 ether_delmulti函数 293 12.13 ip_getmoptions函数 295 12.14 多播输入处理:ipintr函数 296 12.15 多播输出处理:ip_output函数 298 12.16 性能的考虑 301 12.17 小结 301 第13章 IGMP:Internet组管理协议 303 13.1 引言 303 13.2 代码介绍 304 13.2.1 全局变量 304 13.2.2 统计量 304 13.2.3 SNMP变量 305 13.3 igmp结构 305 13.4 IGMP的protosw的结构 306 13.5 加入一个组:igmp_joingroup函数 306 13.6 igmp_fasttimo函数 308 13.7 输入处理:igmp_input函数 311 13.7.1 成员关系查询:IGMP_HOST_ MEMBERSHIP_QUERY 312 13.7.2 成员关系报告:IGMP_HOST_ MEMBERSHIP_REPORT 313 13.8 离开一个组:igmp_leavegroup函数 314 13.9 小结 315 第14章 IP多播选路 316 14.1 引言 316 14.2 代码介绍 316 14.2.1 全局变量 316 14.2.2 统计量 317 14.2.3 SNMP变量 317 14.3 多播输出处理(续) 317 14.4 mrouted守护程序 318 14.5 虚拟接口 321 14.5.1 虚拟接口表 322 14.5.2 add_vif函数 324 14.5.3 del_vif函数 326 14.6 IGMP(续) 327 14.6.1 add_lgrp函数 328 14.6.2 del_lgrp函数 329 14.6.3 grplst_member函数 330 14.7 多播选路 331 14.7.1 多播选路表 334 14.7.2 del_mrt函数 335 14.7.3 add_mrt函数 336 14.7.4 mrtfind函数 337 14.8 多播转发:ip_mforward函数 338 14.8.1 phyint_send函数 343 14.8.2 tunnel_send函数 344 14.9 清理:ip_mrouter_done函数 345 14.10 小结 346 第15章 插口层 348 15.1 引言 348 15.2 代码介绍 349 15.3 socket结构 349 15.4 系统调用 354 15.4.1 举例 355 15.4.2 系统调用小结 355 15.5 进程、描述符和插口 357 15.6 socket系统调用 358 15.6.1 socreate函数 359 15.6.2 超级用户特权 361 15.7 getsock和sockargs函数 361 15.8 bind系统调用 363 15.9 listen系统调用 364 15.10 tsleep和wakeup函数 365 15.11 accept系统调用 366 15.12 sonewconn和soisconnected 函数 369 15.13 connect系统调用 372 15.13.1 soconnect函数 374 15.13.2 切断无连接插口和外部地址的 关联 375 15.14 shutdown系统调用 375 15.15 close系统调用 377 15.15.1 soo_close函数 377 15.15.2 soclose函数 378 15.16 小结 380 第16章 插口I/O 381 16.1 引言 381 16.2 代码介绍 381 16.3 插口缓存 381 16.4 write、writev、sendto和sendmsg 系统调用 384 16.5 sendmsg系统调用 387 16.6 sendit函数 388 16.6.1 uiomove函数 389 16.6.2 举例 390 16.6.3 sendit代码 391 16.7 sosend函数 392 16.7.1 可靠的协议缓存 393 16.7.2 不可靠的协议缓存 393 16.7.3 sosend函数小结 401 16.7.4 性能问题 401 16.8 read、readv、recvfrom和recvmsg 系统调用 401 16.9 recvmsg系统调用 402 16.10 recvit函数 403 16.11 soreceive函数 405 16.11.1 带外数据 406 16.11.2 举例 406 16.11.3 其他的接收操作选项 407 16.11.4 接收缓存的组织:报文边界 407 16.11.5 接收缓存的组织:没有报文边界 408 16.11.6 控制信息和带外数据 409 16.12 soreceive代码 410 16.13 select系统调用 421 16.13.1 selscan函数 425 16.13.2 soo_select函数 425 16.13.3 selrecord函数 427 16.13.4 selwakeup函数 428 16.14 小结 429 第17章 插口选项 431 17.1 引言 431 17.2 代码介绍 431 17.3 setsockopt系统调用 432 17.4 getsockopt系统调用 437 17.5 fcntl和ioctl系统调用 440 17.5.1 fcntl代码 441 17.5.2 ioctl代码 443 17.6 getsockname系统调用 444 17.7 getpeername系统调用 445 17.8 小结 447 第18章 Radix树路由表 448 18.1 引言 448 18.2 路由表结构 448 18.3 选路插口 456 18.4 代码介绍 456 18.4.1 全局变量 458 18.4.2 统计量 458 18.4.3 SNMP变量 459 18.5 Radix结点数据结构 460 18.6 选路结构 463 18.7 初始化:route_init和rtable_init 函数 465 18.8 初始化:rn_init和rn_inithead 函数 468 18.9 重复键和掩码列表 471 18.10 rn_match函数 473 18.11 rn_search函数 480 18.12 小结 481 第19章 选路请求和选路消息 482 19.1 引言 482 19.2 rtalloc和rtalloc1函数 482 19.3 宏RTFREE和rtfree函数 484 19.4 rtrequest函数 486 19.5 rt_setgate函数 491 19.6 rtinit函数 493 19.7 rtredirect函数 495 19.8 选路消息的结构 498 19.9 rt_missmsg函数 501 19.10 rt_ifmsg函数 503 19.11 rt_newaddrmsg函数 504 19.12 rt_msg1函数 505 19.13 rt_msg2函数 507 19.14 sysctl_rtable函数 510 19.15 sysctl_dumpentry函数 514 19.16 sysctl_iflist函数 515 19.17 小结 517 第20章 选路插口 518 20.1 引言 518 20.2 routedomain和protosw结构 518 20.3 选路控制块 519 20.4 raw_init函数 520 20.5 route_output函数 520 20.6 rt_xaddrs函数 530 20.7 rt_setmetrics函数 531 20.8 raw_input函数 532 20.9 route_usrreq函数 534 20.10 raw_usrreq函数 535 20.11 raw_attach、raw_detach和raw_disconnect函数 539 20.12 小结 540 第21章 ARP:地址解析协议 542 21.1 介绍 542 21.2 ARP和路由表 542 21.3 代码介绍 544 21.3.1 全局变量 544 21.3.2 统计量 544 21.3.3 SNMP变量 546 21.4 ARP结构 546 21.5 arpwhohas函数 548 21.6 arprequest函数 548 21.7 arpintr函数 551 21.8 in_arpinput函数 552 21.9 ARP定时器函数 557 21.9.1 arptimer函数 557 21.9.2 arptfree函数 557 21.10 arpresolve函数 558 21.11 arplookup函数 562 21.12 代理ARP 563 21.13 arp_rtrequest函数 564 21.14 ARP和多播 569 21.15 小结 570 第22章 协议控制块 572 22.1 引言 572 22.2 代码介绍 573 22.2.1 全局变量 574 22.2.2 统计量 574 22.3 inpcb的结构 574 22.4 in_pcballoc和in_pcbdetach函数 575 22.5 绑定、连接和分用 577 22.6 in_pcblookup函数 581 22.7 in_pcbbind函数 584 22.8 in_pcbconnect函数 589 22.9 in_pcbdisconnect函数 594 22.10 in_setsockaddr和in_setpeeraddr 函数 595 22.11 in_pcbnotify、in_rtchange和in_losing函数 595 22.11.1 in_rtchange函数 598 22.11.2 重定向和原始插口 599 22.11.3 ICMP差错和UDP插口 600 22.11.4 in_losing函数 601 22.12 实现求精 602 22.13 小结 602 第23章 UDP:用户数据报协议 605 23.1 引言 605 23.2 代码介绍 605 23.2.1 全局变量 606 23.2.2 统计量 606 23.2.3 SNMP变量 607 23.3 UDP 的protosw结构 607 23.4 UDP的首部 608 23.5 udp_init函数 609 23.6 udp_output函数 609 23.6.1 在前面加上IP/UDP首部和mbuf簇 612 23.6.2 UDP检验和计算和伪首部 612 23.7 udp_input函数 616 23.7.1 对收到的UDP数据报的一般确认 616 23.7.2 分用单播数据报 619 23.7.3 分用多播和广播数据报 622 23.7.4 连接上的UDP插口和多接口主机 625 23.8 udp_saveopt函数 625 23.9 udp_ctlinput函数 627 23.10 udp_usrreq函数 628 23.11 udp_sysctl函数 633 23.12 实现求精 633 23.12.1 UDP PCB高速缓存 633 23.12.2 UDP检验和 634 23.13 小结 635 第24章 TCP:传输控制协议 636 24.1 引言 636 24.2 代码介绍 636 24.2.1 全局变量 636 24.2.2 统计量 637 24.2.3 SNMP变量 640 24.3 TCP 的protosw结构 641 24.4 TCP的首部 641 24.5 TCP的控制块 643 24.6 TCP的状态变迁图 645 24.7 TCP的序号 646 24.8 tcp_init函数 650 24.9 小结 652 第25章 TCP的定时器 654 25.1 引言 654 25.2 代码介绍 655 25.3 tcp_canceltimers函数 657 25.4 tcp_fasttimo函数 657 25.5 tcp_slowtimo函数 658 25.6 tcp_timers函数 659 25.6.1 FIN_WAIT_2和2MSL定时器 660 25.6.2 持续定时器 662 25.6.3 连接建立定时器和保活定时器 662 25.7 重传定时器的计算 665 25.8 tcp_newtcpcb算法 666 25.9 tcp_setpersist函数 668 25.10 tcp_xmit_timer函数 669 25.11 重传超时:tcp_timers函数 673 25.11.1 慢起动和避免拥塞 675 25.11.2 精确性 677 25.12 一个RTT的例子 677 25.13 小结 679 第26章 TCP输出 680 26.1 引言 680 26.2 tcp_output概述 680 26.3 决定是否应发送一个报文段 682 26.4 TCP选项 691 26.5 窗口大小选项 692 26.6 时间戳选项 692 26.6.1 哪个时间戳需要回显,RFC1323 算法 694 26.6.2 哪个时间戳需要回显,正确的 算法 695 26.6.3 时间戳与延迟ACK 695 26.7 发送一个报文段 696 26.8 tcp_template函数 707 26.9 tcp_respond函数 708 26.10 小结 710 第27章 TCP的函数 712 27.1 引言 712 27.2 tcp_drain函数 712 27.3 tcp_drop函数 712 27.4 tcp_close函数 713 27.4.1 路由特性 713 27.4.2 资源释放 716 27.5 tcp_mss函数 717 27.6 tcp_ctlinput函数 722 27.7 tcp_notify函数 723 27.8 tcp_quench函数 724 27.9 TCP_REASS宏和tcp_reass函数 724 27.9.1 TCP_REASS宏 725 27.9.2 tcp_reass函数 727 27.10 tcp_trace函数 732 27.11 小结 736 第28章 TCP的输入 737 28.1 引言 737 28.2 预处理 739 28.3 tcp_dooptions函数 745 28.4 首部预测 747 28.5 TCP输入:缓慢的执行路径 752 28.6 完成被动打开或主动打开 752 28.6.1 完成被动打开 753 28.6.2 完成主动打开 756 28.7 PAWS:防止序号回绕 760 28.8 裁剪报文段使数据在窗口内 762 28.9 自连接和同时打开 768 28.10 记录时间戳 770 28.11 RST处理 770 28.12 小结 772 第29章 TCP的输入(续) 773 29.1 引言 773 29.2 ACK处理概述 773 29.3 完成被动打开和同时打开 774 29.4 快速重传和快速恢复的算法 775 29.5 ACK处理 778 29.6 更新窗口信息 784 29.7 紧急方式处理 786 29.8 tcp_pulloutofband函数 788 29.9 处理已接收的数据 789 29.10 FIN处理 791 29.11 最后的处理 793 29.12 实现求精 795 29.13 首部压缩 795 29.13.1 引言 796 29.13.2 首部字段的压缩 799 29.13.3 特殊情况 801 29.13.4 实例 802 29.13.5 配置 803 29.14 小结 803 第30章 TCP的用户需求 805 30.1 引言 805 30.2 tcp_usrreq函数 805 30.3 tcp_attach函数 814 30.4 tcp_disconnect函数 815 30.5 tcp_usrclosed函数 816 30.6 tcp_ctloutput函数 817 30.7 小结 820 第31章 BPF:BSD 分组过滤程序 821 31.1 引言 821 31.2 代码介绍 821 31.2.1 全局变量 821 31.2.2 统计量 822 31.3 bpf_if结构 822 31.4 bpf_d结构 825 31.4.1 bpfopen函数 826 31.4.2 bpfioctl函数 827 31.4.3 bpf_setif函数 830 31.4.4 bpf_attachd函数 831 31.5 BPF的输入 832 31.5.1 bpf_tap函数 832 31.5.2 catchpacket函数 833 31.5.3 bpfread函数 835 31.6 BPF的输出 837 31.7 小结 838 第32章 原始IP 839 32.1 引言 839 32.2 代码介绍 839 32.2.1 全局变量 839 32.2.2 统计量 840 32.3 原始 IP的protosw结构 840 32.4 rip_init函数 842 32.5 rip_input函数 842 32.6 rip_output函数 844 32.7 rip_usrreq函数 846 32.8 rip_ctloutput函数 850 32.9 小结 852 结束语 853 附录A 部分习题的解答 854 附录B 源代码的获取 872 附录C RFC 1122 的有关内容 874 参考文献 895
©️2021 CSDN 皮肤主题: 大白 设计师:CSDN官方博客 返回首页
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、C币套餐、付费专栏及课程。

余额充值