-
发送数据包之前,电脑必须判断对方是否在同一个子网络,然后选择相应的MAC地址。
-
用户的上网设置
必须设置本机的IP地址,子网掩码,网关的IP地址,DNS的IP地址
这4个参数缺一不可,由于它们是给定的,计算机每次开机,都会分到同样的IP地址,所以这种被称为"静态IP地址上网"。 但是这样的设置很专业,普通用户望而生畏,而且如果一台电脑的IP地址保持不变,其他电脑就不能使用这个地址,不够灵活。所以大多数用户使用"动态IP地址上网"。 -
动态IP地址、DHCP协议
1.指的是开机后,会自动分配到一个IP地址,不用人为设定。它使用的协议叫做DHCP协议。(Dynamic Host Configuration Protocol 动态主机配置协议)
2.DHCP协议规定:每一个子网络中,有一台计算机负责管理本网络的所有IP地址,它叫做DHCP服务器。新的计算机加入网络,必须向DHCP服务器发送一个DHCP请求数据包,申请IP和网络参数。
3.如果2台计算机在同一个子网络,必须知道对方的MAC和IP地址,才能发送数据包。但是,新加入的计算机不知道这2个地址,怎么发送数据包呢?
DHCP是一种应用层协议,建立在UDP协议之上,所以整个数据包是这样的:
最前面的以太网标头,设置本机的MAC地址和接收方(DHCP服务器),前者就是本机网卡的MAC地址,后者这时不知道,就填入一个广播地址:FF-FF-FF-FF-FF-FF。
后面的IP标头,设置本机的IP地址和接收方的IP地址。这时,对于这2者,本机都不知道。于是,发出方的IP就设为0.0.0.0,接收方的IP地址设为255.255.255.255。
最后的UDP标头,设置发出方的端口和接收方的端口。这一部分是DHCP协议规定好的,发出方是68端口,接收方是67端口。
这个数据包构造完成后就可以发出了,以太网是广播发送,同一个子网络的每台计算机都收到了这个包 。因为接收方的MAC地址是广播地址,看不出是发给谁的,所以每台收到这个包的计算机,还必须分析这个包的IP地址,才能确定是不是发给自己的,当看到发出方IP是0.0.0.0,接收方是255.255.255.255,于是DHCP服务器指导这个包是发给我的,其他计算机就可以丢弃这个包。
DHCP服务器读出这个包的数据内容,分配好IP地址,发送回去一个DHCP响应数据包。这个响应包的结构也是类似的,以太网标头的MAC地址是双方的网卡地址,IP标头的IP地址是DHCP服务器的IP地址和255.255.255.255,UDP标头的端口是67发出方和68接收方,分配给请求段的IP地址和本网络的具体参数则包含在Data部分。
新加入的计算机收到这个响应包,于是就知道了所分配的参数。 -
DNS协议
1.DNS协议可以将网址转换为IP地址,已知DNS服务器为8.8.8.8,于是向这个地址发送一个DNS数据包(53端口),然后DNS服务器做出响应,告诉我们网址的IP地址是多少。 -
子网掩码
接下来我们要判断,这个IP地址是不是在同一个子网络,这就要用到子网掩码。
如果不在同一网络,我们要向网址发送数据包,必须通过网关转发,也就是说接收方的MAC地址将是网关的MAC地址。 -
应用层协议
浏览网页用的是HTTP协议,它会被嵌在TCP数据包之中。假设这个部分的长度为4960字节。 -
TCP协议
TCP数据包需要设置端口,接收方的HTTP端口默认是80,发送方的端口是一个随机生成的1024-65535之间的整数。
TCP数据包的标头长度为20字节,加上嵌入的HTTP数据包,总长度变为4980字节。 -
IP协议
TCP数据包再嵌入IP数据包。IP数据包需要设置双方的IP地址,这是已知的。
IP数据包的标头长度为20字节,加上嵌入的TCP数据包,总长度变为5000字节。 -
以太网协议
最后IP数据包嵌入以太网数据包,以太网数据包需要设置双方的MAC地址,发送方方为本机的网卡MAC地址,接收方为网关的的MAC地址(通过ARP协议得到)
以太网数据包的数据部分,最大长度为1500字节。而现在IP数据包长度为5000字节。因此,IP数据包必须分割成4个包,所以4个包的IP数据包的长度分别为1500,1500,1500,560。 -
服务器端响应
经过多个网关的转发,服务器收到了这4个以太网数据包。
根据IP标头的序号,服务器将4个包拼起来,取出完整的TCP数据包,然后读出里面的HTTP请求,接着做出HTTP响应,再用TCP协议发回来。
本机收到HTTP响应以后,就可以将网页显示出来,完成一次网络通信。
浅析互联网协议(二)
最新推荐文章于 2024-07-11 08:57:39 发布