Wireshark入门:分析DHCP协议的运行

客户端主机使用DHCP动态获得IP地址主要分为以下4步:

1,(Discover)

客户端使用IP地址0.0.0.0(因为客户端还没有IP地址)发送一个广播(到255.255.255.255),来询问谁是DHCP服务器,广播域中的其他客户端主机会忽略收到的这个报文,因为他们不是DHCP服务器。

用Wireshark抓到的这个报文包如下所示:

可以看到客户端还没有IP地址

(注:DHCP协议的前身是Bootstrap Protocol,所以这里看到的是Bootp)

 

2,(Offer)
DHCP服务器收到这条请求分配IP地址的数据包之后,会查看服务器维护的IP资源池,如果有可用IP,就会给主机提供一个IP地址

如下所示:

可以看到,DHCP服务器分配给主机的IP地址是192.168.0.164

(注:这里DHCP服务器使用的是到192.168.0.164的单播数据包,因为客户端主机目前还没有IP地址,所以在这个单播IP发送之前,服务器会使用由ARP提供的客户端主机的MAC地址与之通信,这里可见使用MAC地址通信是成功的,如果MAC地址通信失败,那么服务器会使用广播的方式提供(Offer)数据包)

 

3,(Request)

客户端主机收到这个提供的IP地址之后,会再次请求服务器,询问自己可以使用这个IP地址吗,

如下所示:

这次客户端请求与第一次请求不同的是,这次请求已明确了想要获得的IP地址是192.168.0.164,

 

4,(ACK)

服务器收到这个请求之后,进行ACK确认

 

至此,一次动态分配IP的过程结束。

 

DHCP协议还有其他4中消息类型,分别是:拒绝、NAK、释放、通知。本文只是简单介绍DHCP的常规运行,这里就不再介绍这4种类型。

 

posted @ 2014-12-03 14:08  张楠0412  阅读(834)  评论(0编辑  收藏  举报