女的下面喷水舒服吗?:DHCP的工作原理

来源:百度文库 编辑:杭州交通信息网 时间:2024/05/07 14:17:13

DHCP:Dynamic Host Configuration Protocol,即动态主机配置协议。更通俗的说,DHCP就是为我们网络中的计算机配置IP地址相关信息的服务协议,提供该服务的服务器叫做DHCP服务器。这样我们就不需要手动在为每台机器配置IP地址信息了。
在“网上邻居”右击选择“属性”,找到你的网络连接,右击选择“属性”,双击TCP/IP协议,选择“自动获得IP地址”和“自动获得DNS服务器地址”。
这样当你的电脑第一次连接到网络中后,会首先查找自己的IP地址配置信息。如果发现是配置成为自动获取,便会自动在网络中大喊:“我是一台主机,我需要上网的IP地址配置信息,请问那台机器可以给我”(因为客户端还不知道自己属于哪一个网络,所以封包的源IP地址为0.0.0.0,而目的IP地址为255.255.255.255,即所有主机都接受,后边还会附上DHCPDISCOVER封包)。
默认情况下,你的电脑会等待1秒钟,如果网络中没人理它,它就会再喊一次,这次它会等待9秒。如果还没人搭理它还会再喊两次(够固执吧),分别再等13秒和16秒。如果最后还是没人理,它就会认为网络中没有DHCP服务器。
当网络中的DHCP服务器听到了你电脑发的广播消息时,它会翻自己的小账本,这个小账本里边记录着IP地址的范围段,以及其他IP地址配置信息,如DNS和WINS。它会从小账本中未使用的IP地址中,选择一个最靠前的IP,连同其它 TCP/IP设定,做成一个数据包,发给你的机器。注意,由于你的机器此时还没有IP,你的机器会根据回复包里的MAC地址判断这个回复是否属于它。同时DHCP还会在包里写上:“小子,这个IP不是一直给你用,只是暂时租给你(如租8天),到期前想着再来续租,否则我就租给别人了。”
你的机器可能会收到来自多个DHCP分给的IP地址配置信息,它可没那么贪心,默认情况下,它会将它最先接到的IP地址配置信息配置到自己的网卡上,并且它还会喊两声,一是说:“我已经选用了来自某某DHCP的IP配置信息了,其他DHCP的分配请收回吧”(广播包)。二是说:“我是某某计算机,我的IP地址是XXX,有人用的跟我一样吗?(ARP查询,如果有,你的机器会放弃已经得到的IP,而是再去申请一个新的IP)”
DHCP服务器在接受到你的机器发来的回复后,还会在跟你的机器说:“OK,你的租约现在开始生效。”(DHCPACK回应,以确认IP租约的正式生效)。
你的机器再得到IP地址之后,会时刻记着租约到期的时间,通常在租期过了一半的时候,会直接跟给它发放IP地址配置信息的DHCP说:“我的地址快到期了,申请续租”(Dhcprequest信息)。通常情况下,DHCP服务器会告诉你的机器“OK,允许你继续租下去!”(回应Dhcpack确认)。但是如果该配置信息已经失效或已经被其它机器强先申请了去,这台DHCP服务器会让你重新再申请。
如果你想强制你的机器重新获得IP地址的配置信息,可以选择“开始/运行”,输入cmd回车,在弹出的对话框中输入“ipconfig /renew”即可。

DHCP 是 Dynamic Host Configuration Protocol(动态主机分配协议)缩写,它的前身是 BOOTP。BOOTP 原本是用于无磁盘主机连接的网络上面的:网络主机使用 BOOT ROM 而不是磁盘起动并连接上网络,BOOTP 则可以自动地为那些主机设定 TCP/IP 环境。但 BOOTP 有一个缺点:您在设定前须事先获得客户端的硬件地址,而且,与 IP 的对应是静态的。换而言之,BOOTP 非常缺乏 "动态性" ,若在有限的 IP 资源环境中,BOOTP 的一对一对应会造成非常可观的浪费。 DHCP 可以说是 BOOTP 的增强版本,它分为两个部份:一个是服务器端,而另一个是客户端。所有的 IP 网络设定数据都由 DHCP 服务器集中管理,并负责处理客户端的 DHCP 要求;而客户端则会使用从服务器分配下来的IP环境数据。比较起 BOOTP ,DHCP 透过 "租约" 的概念,有效且动态的分配客户端的 TCP/IP 设定,而且,作为兼容考虑,DHCP 也完全照顾了 BOOTP Client 的需求。 DHCP 的分配形式 首先,必须至少有一台 DHCP 工作在网络上面,它会监听网络的 DHCP 请求,并与客户端搓商 TCP/IP 的设定环境。它提供两种 IP 定位方式:
Automatic Allocation
自动分配,其情形是:一旦 DHCP 客户端第一次成功的从 DHCP 服务器端租用到 IP 地址之后,就永远使用这个地址。
Dynamic Allocation
动态分配,当 DHCP 第一次从 HDCP 服务器端租用到 IP 地址之后,并非永久的使用该地址,只要租约到期,客户端就得释放(release)这个 IP 地址,以给其它工作站使用。当然,客户端可以比其它主机更优先的更新(renew)租约,或是租用其它的 IP 地址。 动态分配显然比自动分配更加灵活,尤其是当您的实际 IP 地址不足的时候,例如:您是一家 ISP ,只能提供 200 个IP地址用来给拨接客户,但并不意味着您的客户最多只能有 200 个。因为要知道,您的客户们不可能全部同一时间上网的,除了他们各自的行为习惯的不同,也有可能是电话线路的限制。这样,您就可以将这 200 个地址,轮流的租用给拨接上来的客户使用了。这也是为什么当您查看 IP 地址的时候,会因每次拨接而不同的原因了(除非您申请的是一个固定 IP ,通常的 ISP 都可以满足这样的要求,这或许要另外收费)。当然,ISP 不一定使用 DHCP 来分配地址,但这个概念和使用 IP Pool 的原理是一样的。 DHCP 除了能动态的设定 IP 地址之外,还可以将一些 IP 保留下来给一些特殊用途的机器使用,它可以按照硬件地址来固定的分配 IP 地址,这样可以给您更大的设计空间。同时,DHCP 还可以帮客户端指定 router、netmask、DNS Server、WINS Server、等等项目,您在客户端上面,除了将 DHCP 选项打勾之外,几乎无需做任何的 IP 环境设定。 DHCP 的工作原理 根据客户端是否第一次登录网络,DHCP 的工作形式会有所不同。 第一次登录的时候:
寻找 Server。当 DHCP 客户端第一次登录网络的时候,也就是客户发现本机上没有任何 IP 数据设定,它会向网络发出一个 DHCP DISCOVER 封包。因为客户端还不知道自己属于哪一个网络,所以封包的来源地址会为 0.0.0.0 ,而目的地址则为 255.255.255.255 ,然后再附上 DHCP discover 的信息,向网络进行广播。 在 Windows 的预设情形下,DHCP discover 的等待时间预设为 1 秒,也就是当客户端将第一个 DHCP discover 封包送出去之后,在 1 秒之内没有得到响应的话,就会进行第二次 DHCP discover 广播。若一直得不到响应的情况下,客户端一共会有四次 DHCP discover 广播(包括第一次在内),除了第一次会等待 1 秒之外,其余三次的等待时间分别是 9、13、16 秒。如果都没有得到 DHCP 服务器的响应,客户端则会显示错误信息,宣告 DHCP discover 的失败。之后,基于使用者的选择,系统会继续在 5 分钟之后再重复一次 DHCP discover 的过程。
提供 IP 租用地址。当 DHCP 服务器监听到客户端发出的 DHCP discover 广播后,它会从那些还没有租出的地址范围内,选择最前面的空置 IP ,连同其它 TCP/IP 设定,响应给客户端一个 DHCP OFFER 封包。 由于客户端在开始的时候还没有 IP 地址,所以在其 DHCP discover 封包内会带有其 MAC 地址信息,并且有一个 XID 编号来辨别该封包,DHCP 服务器响应的 DHCP offer 封包则会根据这些资料传递给要求租约的客户。根据服务器端的设定,DHCP offer 封包会包含一个租约期限的信息。
接受 IP 租约。如果客户端收到网络上多台 DHCP 服务器的响应,只会挑选其中一个 DHCP offer 而已(通常是最先抵达的那个),并且会向网络发送一个DHCP request广播封包,告诉所有 DHCP 服务器它将指定接受哪一台服务器提供的 IP 地址。 同时,客户端还会向网络发送一个 ARP 封包,查询网络上面有没有其它机器使用该 IP 地址;如果发现该 IP 已经被占用,客户端则会送出一个 DHCPDECLINE 封包给 DHCP 服务器,拒绝接受其 DHCP offer ,并重新发送 DHCP discover 信息。 事实上,并不是所有 DHCP 客户端都会无条件接受 DHCP 服务器的 offer ,尤其这些主机安装有其它 TCP/IP 相关的客户软件。客户端也可以用 DHCP request 向服务器提出 DHCP 选择,而这些选择会以不同的号码填写在 DHCP Option Field 里面:
换一句话说,在 DHCP 服务器上面的设定,未必是客户端全都接受,客户端可以保留自己的一些 TCP/IP 设定。而主动权永远在客户端这边。
租约确认。当 DHCP 服务器接收到客户端的 DHCP request 之后,会向客户端发出一个 DHCPACK 响应,以确认 IP 租约的正式生效,也就结束了一个完整的 DHCP 工作过程。 如上的工作流程如下图:
DHCP 发放流程第一次登录之后: 一旦 DHCP 客户端成功地从服务器哪里取得 DHCP 租约之后,除非其租约已经失效并且 IP 地址也重新设定回 0.0.0.0 ,否则就无需再发送 DHCP discover 信息了,而会直接使用已经租用到的 IP 地址向之前之 DHCP 服务器发出 DHCP request 信息,DHCP 服务器会尽量让客户端使用原来的 IP 地址,如果没问题的话,直接响应 DHCPack 来确认则可。如果该地址已经失效或已经被其它机器使用了,服务器则会响应一个 DHCPNACK 封包给客户端,要求其从新执行 DHCP discover。 至于 IP 的租约期限却是非常考究的,并非如我们租房子那样简单, 以 NT 为例子:DHCP 工作站除了在开机的时候发出 DHCP request 请求之外,在租约期限一半的时候也会发出 DHCP request ,如果此时得不到 DHCP 服务器的确认的话,工作站还可以继续使用该 IP ;然后在剩下的租约期限的再一半的时候(即租约的75%),还得不到确认的话,那么工作站就不能拥有这个 IP 了。至于为什么不是到租约期限完全结束才放弃 IP 呢?,对不起,小弟也是不学无术之人,没有去深究了,只知道要回答 MCSE 题目的时候,您一定要记得 NT 是这么工作的就是了。 要是您想退租,可以随时送出 DHCPLEREASE 命令解约,就算您的租约在前一秒钟才获得的。
跨网络的 DHCP 运作 从前面描述的过程中,我们不难发现:DHCDISCOVER 是以广播方式进行的,其情形只能在同一网络之内进行,因为 router 是不会将广播传送出去的。但如果 DHCP 服务器安设在其它的网络上面呢?由于 DHCP 客户端还没有 IP 环境设定,所以也不知道 Router 地址,而且有些 Router 也不会将 DHCP 广播封包传递出去,因此这情形下 DHCP DISCOVER 是永远没办法抵达 DHCP 服务器那端的,当然也不会发生 OFFER 及其它动作了。要解决这个问题,我们可以用 DHCP Agent (或 DHCP Proxy )主机来接管客户的 DHCP 请求,然后将此请求传递给真正的 DHCP 服务器,然后将服务器的回复传给客户。这里,Proxy 主机必须自己具有路由能力,且能将双方的封包互传对方。 若不使用 Proxy,您也可以在每一个网络之中安装 DHCP 服务器,但这样的话,一来设备成本会增加,而且,管理上面也比较分散。当然喽,如果在一个十分大型的网络中,这样的均衡式架构还是可取的。端视您的实际情况而定了。 DHCP封包格式
以下为各字段的简要说明: OP
若是 client 送给 server 的封包,设为 1 ,反向为 2 。 HTYPE
硬件类别,Ethernet 为 1 。
HLEN
硬件地址长度, Ethernet 为 6 。
HOPS
若封包需经过 router 传送,每站加 1 ,若在同一网内,为 0 。
TRANSACTION ID
DHCP REQUEST 时产生的数值,以作 DHCPREPLY 时的依据。
SECONDS
Client 端启动时间(秒)。
FLAGS
从 0 到 15 共 16 bits ,最左一 bit 为 1 时表示 server 将以广播方式传送封包给 client ,其余尚未使用。
ciaddr
要是 client 端想继续使用之前取得之 IP 地址,则列于这里。
yiaddr
从 server 送回 client 之 DHCP OFFER 与 DHCPACK 封包中,此栏填写分配给 client 的 IP 地址。
siaddr
若 client 需要透过网络开机,从 server 送出之 DHCP OFFER、DHCPACK、DHCPNACK 封包中,此栏填写开机程序代码所在 server 之地址。
giaddr
若需跨网域进行 DHCP 发放,此栏为 relay agent 的地址,否则为 0 。
chaddr
Client 之硬件地址。
sname
Server 之名称字符串,以 0x00 结尾。
file
若 client 需要透过网络开机,此栏将指出开机程序名称,稍后以 TFTP 传送。
options
允许厂商定议选项(Vendor-Specific Area),以提供更多的设定信息(如:Netmask、Gateway、DNS、等等)。其长度可变,同时可携带多个选项,每一选项之第一个 byte 为信息代码,其后一个 byte 为该项数据长度,最后为项目内容。 CODE LEN VALUE 此字段完全兼容 BOOTP ,同时扩充了更多选项。其中,DHCP 封包可利用编码为 0x53 之选项来设定封包类别:项值 类别
1 DHCP DISCOVER
2 DHCP OFFER
3 DHCP REQUEST
4 DHCPDECLINE
5 DHCPACK
6 DHCPNACK
7 DHCPRELEASE DHCP 的选项非常多,有空请查阅 RFC 或相关文献,并好好理解,这里不再叙述了。
DHCP 协议之 RFC 文件 RFC-951、RFC-1084、RFC-1123、RFC-1533、RFC-1534、RFC-1497、RFC-1541

DHCP:Dynamic Host Configuration Protocol,即动态主机配置协议。更通俗的说,DHCP就是为我们网络中的计算机配置IP地址相关信息的服务协议,提供该服务的服务器叫做DHCP服务器。这样我们就不需要手动在为每台机器配置IP地址信息了。
在“网上邻居”右击选择“属性”,找到你的网络连接,右击选择“属性”,双击TCP/IP协议,选择“自动获得IP地址”和“自动获得DNS服务器地址”。
这样当你的电脑第一次连接到网络中后,会首先查找自己的IP地址配置信息。如果发现是配置成为自动获取,便会自动在网络中大喊:“我是一台主机,我需要上网的IP地址配置信息,请问那台机器可以给我”(因为客户端还不知道自己属于哪一个网络,所以封包的源IP地址为0.0.0.0,而目的IP地址为255.255.255.255,即所有主机都接受,后边还会附上DHCPDISCOVER封包)。
默认情况下,你的电脑会等待1秒钟,如果网络中没人理它,它就会再喊一次,这次它会等待9秒。如果还没人搭理它还会再喊两次(够固执吧),分别再等13秒和16秒。如果最后还是没人理,它就会认为网络中没有DHCP服务器。
当网络中的DHCP服务器听到了你电脑发的广播消息时,它会翻自己的小账本,这个小账本里边记录着IP地址的范围段,以及其他IP地址配置信息,如DNS和WINS。它会从小账本中未使用的IP地址中,选择一个最靠前的IP,连同其它 TCP/IP设定,做成一个数据包,发给你的机器。注意,由于你的机器此时还没有IP,你的机器会根据回复包里的MAC地址判断这个回复是否属于它。同时DHCP还会在包里写上:“小子,这个IP不是一直给你用,只是暂时租给你(如租8天),到期前想着再来续租,否则我就租给别人了。”
你的机器可能会收到来自多个DHCP分给的IP地址配置信息,它可没那么贪心,默认情况下,它会将它最先接到的IP地址配置信息配置到自己的网卡上,并且它还会喊两声,一是说:“我已经选用了来自某某DHCP的IP配置信息了,其他DHCP的分配请收回吧”(广播包)。二是说:“我是某某计算机,我的IP地址是XXX,有人用的跟我一样吗?(ARP查询,如果有,你的机器会放弃已经得到的IP,而是再去申请一个新的IP)”
DHCP服务器在接受到你的机器发来的回复后,还会在跟你的机器说:“OK,你的租约现在开始生效。”(DHCPACK回应,以确认IP租约的正式生效)。
你的机器再得到IP地址之后,会时刻记着租约到期的时间,通常在租期过了一半的时候,会直接跟给它发放IP地址配置信息的DHCP说:“我的地址快到期了,申请续租”(Dhcprequest信息)。通常情况下,DHCP服务器会告诉你的机器“OK,允许你继续租下去!”(回应Dhcpack确认)。但是如果该配置信息已经失效或已经被其它机器强先申请了去,这台DHCP服务器会让你重新再申请。
如果你想强制你的机器重新获得IP地址的配置信息,可以选择“开始/运行”,输入cmd回车,在弹出的对话框中输入“ipconfig /renew”即可。

DHCP是Dynamic Host Configuration Protocol的缩写,它是TCP/IP协议簇中的一种,主要是用来给网络客户机分配动态的IP地址。这些被分配的IP地址都是DHCP服务器预先保留的一个由多个地址组成的地址集,并且它们一般是一段连续的地址。

理解DHCP服务

使用DHCP时必须在网络上有一台DHCP服务器,而其他机器执行DHCP客户端。当DHCP客户端程序发出一个信息,要求一个动态的IP地址时,DHCP服务器会根据目前已经配置的地址,提供一个可供使用的IP地址和子网掩码给客户端。

1. 使用DHCP的优点

DHCP使服务器能够动态地为网络中的其他服务器提供IP地址,通过使用DHCP,就可以不给Intranet网中除DHCP、DNS和WINS服务器外的任何服务器设置和维护静态IP地址。使用DHCP可以大大简化配置客户机的TCP/IP的工作,尤其是当某些TCP/IP参数改变时,如网络的大规模重建而引起的IP地址和子网掩码的更改。

DHCP服务器是运行Microsoft TCP/IP、DHCP服务器软件和Windows NT Server的计算机,DHCP客户机则是请求TCP/IP配置信息的TCP/IP主机。DHCP使用客户机/服务器模型,网络管理员可以创建一个或多个维护TCP/IP配置信息的DHCP服务器,并且将其提供给客户机。

DHCP服务器上的IP地址数据库包含如下项目:

● 对互联网上所有客户机的有效配置参数。

● 在缓冲池中指定给客户机的有效IP地址,以及手工指定的保留地址。

● 服务器提供租约时间,租约时间即指定IP地址可以使用的时间。

在网络中配置DHCP服务器有如下优点:

● 管理员可以集中为整个互联网指定通用和特定子网的TCP/IP参数,并且可以定义使用保留地址的客户机的参数。

● 提供安全可信的配置。DHCP避免了在每台计算机上手工输入数值引起的配置错误,还能防止网络上计算机配置地址的冲突。

● 使用DHCP服务器能大大减少配置花费的开销和重新配置网络上计算机的时间,服务器可以在指派地址租约时配置所有的附加配置值。

● 客户机不需手工配置TCP/IP。

● 客户机在子网间移动时,旧的IP地址自动释放以便再次使用。在再次启动客户机时,DHCP服务器会自动为客户机重新配置TCP/IP。

● 大部分路由器可以转发DHCP配置请求,因此,互联网的每个子网并不都需要DHCP服务器。

注释:

如果要使用DHCP服务器支持跨越多重路由器的子网,则路由器可能需要硬件升级。路由器必须支持RFC 1533、1534、1541和1542。

2. DHCP分配地址的方式

DHCP使用客户/服务器模式,网络管理员建立一个或多个DHCP服务器,在这些服务器中保存了可以提供给客户机的TCP/IP配置信息。这些信息包括网络客户的有效配置参数、分配给客户的有效IP地址池(其中包括为手工配置而保留的地址)、服务器提供的租约持续时间。

如果将TCP/IP网络上的计算机设定为从DHCP服务器获得IP地址,这些计算机则成为DHCP客户机。启动DHCP客户机时,它与DHCP服务器通信以接收必要的TCP/IP配置信息。该配置信息至少包含一个IP地址和子网掩码,以及与配置有关的租约。

DHCP服务器有3种为DHCP客户机分配TCP/IP地址的方式:

● 手工分配:在手工分配中,网络管理员在DHCP服务器通过手工方法配置DHCP客户机的IP地址。当DHCP客户机要求网络服务时,DHCP服务器把手工配置的IP地址传递给DHCP客户机。

● 自动分配:在自动分配中,不需要进行任何的IP地址手工分配。当DHCP客户机第一次向DHCP服务器租用到IP地址后,这个地址就永久地分配给了该DHCP客户机,而不会再分配给其他客户机。

● 动态分配:当DHCP客户机向DHCP服务器租用IP地址时,DHCP服务器只是暂时分配给客户机一个IP地址。只要租约到期,这个地址就会还给DHCP服务器,以供其他客户机使用。如果DHCP客户机仍需要一个IP地址来完成工作,则可以再要求另外一个IP地址。

动态分配方法是惟一能够自动重复使用IP地址的方法,它对于暂时连接到网上的DHCP客户机来说尤其方便,对于永久性与网络连接的新主机来说也是分配IP地址的好方法。DHCP客户机在不再需要时才放弃IP地址,如DHCP客户机要正常关闭时,它可以把IP地址释放给DHCP服务器,然后DHCP服务器就可以把该IP地址分配给申请IP地址的DHCP客户机。

使用动态分配方法可以解决IP地址不够用的困扰,例如C类网络只能支持254台主机,而网络上的主机有三百多台,但如果网上同一时间最多有200个用户,此时如果使用手工分配或自动分配将不能解决这一问题。而动态分配方式的IP地址并不固定分配给某一客户机,只要有空闲的IP地址,DHCP服务器就可以将它分配给要求地址的客户机;当客户机不再需要IP地址时,就由DHCP服务器重新收回