目录
一、实验目的
二、实验步骤
三、实验环境
四、实验过程与分析
1. Capture a Trace 捕获
2. Inspect the Trace 检查捕获
3. IP Packet Structure IP结构
4. Internet Paths 互联网路径
5. IP Header Checksum IP头部校验和
6. Explore on your own
1. Capture a Trace
2. inspect the trace
3. IP Packet Structure
4. Internet Paths
5. IP Header Checksum
6. Explore on your own
· wireshark;
· wget (Linux & win):命令行程序获取URL。
· Traceroute工具:显示数据包在IP网络经过的路由器的IP地址。广泛应用于网络故障排除。
程序利用增加存活时间TTL值实现功能。每当数据包经过一个路由器,存活时间--;
存活时间== 0时,主机取消数据包,并发送一个ICMP TTL数据包给原数据包发送者。
程序发出的第1-3个数据包的TTL值= 1;4-6数据包TTL值 = 2;… ;从而得到这一串数据包的路径(IP不保证每个数据包的路径相同)。
如果显示结果为*:说明某些路由不会为TTL超时发送“已超时”信息or禁止ICMP ERROR MESSAGE。
1. 远程服务器上选择www.qq.com这个URL,检查是否可用wget获取内容;
得到200OK响应,说明获取成功。
2. 对www.qq.com 执行traceroute检查是否能够获得网络路径信息。
3.启动wireshark,设置filter为 tcp port 80。由于www.qq.com是IPv6,下面用www.baidu.com
· 从顶部面板中选择捕获的一个数据包,在中间面板中查看详细信息,底部面板查看具体字节信息。
· version 版本号 4b:IPv4-IPversion4,version = 0100;IPv6-IPversion6,version = 0110.
· header length header字段长度 4b:IP header段总长度包含多少个32位 = 20 B = 160 bits;显示0101 = 5 = 20/(8*4)
· Differentiated Services Field 区分服务 1B = 8b:DSCP和CU(ECN)组合成一个可拓展性相对较强的方法,从而保证IP的服务质量。例如,网络中出现拥塞时,TCP/IP会主动丢弃数据包,源端检测到丢包之后,减小拥塞窗口,降低传输速率;但是,当协商好ECN之后,支持ECN的路由器能够在发生拥塞时进行标记,发出即将拥塞的信号,不用直接丢弃数据包。
DSCP 6b:区分服务代码点;
ECN (=CU) 2b:支持端到端的网络拥塞通知。
00:Not-ECT非ECN-Capable;
01:ECN运输能力0;
10:ECN运输能力1;
11:遇到拥塞,CE;
· total length总长度 2B:这里总长度=1400
· Identification 标识段 2B:
· flags 标记 3b:只有后两位有效。
第二位:DF=1,路由器不能对报文进行分片处理;
第三位:MF:多分片,当路由器对报文进行分片时只有最后一个分片的MF位=0,其余都为1。
· fragment offset 分片偏移 12b:
· TTL time to live生存时间 1B:数据报到达目的地址destination的最大报文跳数,防止出现路由循环。每经过1个路由TTL--。
· protocol 协议 1B:标识上层协议。1-ICMP;2-IGMP;6-TCP;17-UDP;89-OSPF。
· header checksum 头部校验和 2B:只校验header部分。
· source 源IP 4B:
· destination 目的IP 4B:
Turn-in: Hand in your drawing of an IP packet and the answers to the questions above.
· IP地址:互联网协议地址Internet Protocol Address。进行TCP/IP的基础。
为互联网上每一个网络、每一台主机分配的一个逻辑地址,从而屏蔽物理地址的差异;
每个连接到网络的计算机都有一个IP地址。
· IPv4网络地址 4B:(byte1. byte2.byte3.byte4)
A类IP地址: 用于大型的网络、政府机构;byte1网络号;
byte1最高位=0;可用IP范围:1.0.0.1-127.255.255.254。
B类IP地址: 用于中等规模网络、中型企业;byte1.byte2网络号;
byte1最高位=10;可用IP范围:128.0.0.1-191.255.255.254。
C类IP地址: 用于小型网络、自由分配;byte1.byte2.byte3网络号;
byte1最高位=110;可用IP范围:192.0.0.1-223.255.255.254。
D类IP地址: 用于一对多通信;IPv4中不区分网络地址和主机地址;
byte1最高位=1110;D类IP范围:224.0.0.0-239.255.255.255。
E类IP地址: 用于研究实验,Internet中没有可用的E类IP地址;不区分网络地址和主机地址;
byte1最高位=1111;E类IP范围:240.0.0.0-247.255.255.255。
ps. ① 255.255.255.255表示本地网络的广播地址,不能被转发、不能过网关,会发送相同的物理网络段到所有主机中。
② 监听0.0.0.0端口相当于监听本机中所有IP端口;0.0.0.0表示本机中所有的IPv4地址。
ps. 用到的IP查询网址:123.56.4.112地理位置查询及详细问答 | IP地址 (简体中文) 、http://ip.yqie.com
Turn-in: Hand in your drawing, and traceroute output if it was not supplied to you.
按照以下步骤计算checksum是否正确:
1. 将header分成10个2 bytes (16 bits),即写成10个4位的16进制数,见wireshark底部面板。
2. 用常规加法将这10个数相加;
3. 取前导数字(超过单词大小的16进制数),加到余数中。
4. 结果应该等于0xFFFF = negative zero = -0
其实也就是,除了checksum字段,其他9个字段按照2B的16进制写法相加,前导数字再加,将这个和的结果取反,即为IP checksum。
打开wireshark中的validate IPv4checksum功能
Turn-in: Hand in your sums. Next to each word you add note the IPv4 fields to which it corresponds.
We encourage you to explore IP on your own once you have completed this lab. Some ideas:
IPv4 定义的地址空间是有限的,用4B=32bits表示,然而随着互联网的发展,IPv4的有限地址空间将被耗尽,需要更大的地址空间。相对于IPv4,IPv6具有更大的地址空间、更小的路由表、增强的组播、对自动配置支持、更高的安全性。
区别:
IP地址格式:IPv4中为4B,IPv6中16B 格式为2B:2B:2B:2B:2B:2B:2B:2B。在IP header中的表现即source地址、destination地址的区别。
IP header 长度:IPv4 header 长度为20B – 60B; IPv6 header固定40B
分片:IPv6 header 不允许在除了源、目的地之外的中间路由器上进行分片与重新组装。
header checksum:IPv6 取消;
VPN:Virtual Private Network 虚拟专用网络。通过VPN可以模拟点对点专用链接的方式,通过共享/公共网络在两台计算机之间发送数据。
VPN通信过程的简单概括:
1. 客户机向VPN服务器发送请求;
2. VPN服务器响应;向客户机发出身份质询,客户机将加密的用户身份验证响应信息发送给VPN服务器;
3. VPN服务器根据用户数据库检查该响应。
如果账户有效,VPN服务器将检查该用户是否具有远程访问权限;
如果该用户拥有远程访问的权限,VPN服务器接受此连接;
4. 最后,VPN服务器将在身份验证过程中产生的客户机和服务器公有密钥将用来对数据进行加密,然后通过VPN隧道技术进行封装、加密、传输到目的内部网络。
IPsec:Internet Protocol Security,是IP网络提供安全性协议、服务的集合,VPN中常用的一种技术。其中3个重要协议:IKE/AH/ESP
IKE:Internet Key Exchange 因特网密钥交换。基于UDP的应用层协议。
AH:Authentication Header 认证头。对整个IP报文进行数据源认证、完整性校验,不提供加密功能。
ESP:Encapsulating Security Payload 封装安全载荷。对IP报文进行数据源认证、完整性校验;对数据进行加密。