6.2.5 网络基本服务----动态主机配置协议DHCP

6.2.5 网络基本服务----动态主机配置协议DHCP

动态主机配置协议允许一台计算机加入新的网络时可自动获取网络配置信息,不用人工参与。连网的计算机需要配置的参数包括

  1. IP地址
  2. 子网掩码
  3. 默认路由器的IP地址
  4. 域名服务器IP地址

DHCP与DNS、FTP、Telnet一样也采用客户服务器模式。

一、DHCP的作用

我们先来了解一下主机如何接入互联网,如图

目前主要有两类接入互联网方式

  1. 宽带接入
  2. 局域网接入

宽带

宽带接入多用于家庭,常见有两种方式,一种是通过非对称数字用户线路,即ADSL线路接入互联网,一种是通过有线电视网接入互联网。以ADSL接入为例,用户端的modem实现数字信号和模拟信号之间的转换,电话网络分离器,采用频分多路复用技术(3.3.1 多路复用技术(一))在传统的电话线路上传输低频的电话信号和高频的上网数字调制信号,终端设有分离器和DSL接入复用器,将电话信号和上网信号,分别连入电话网和互联网,如果家中只有一台主机上网,可以直接将主机直接连接在modem的以太网口,否则就需要一台宽带路由器将家中的若干主机连接到互联网,宽带路由器不仅具有路由器的功能,还集成了交换机模块,无线宽带路由器相当于路由器加以太交换机加无线接入点以及无线交换机。

如下图是通过局域网接入互联网

局域网

校园网、企业网中的主机常采用局域网接入的方式,主机通过网线或无线直接连接到以太或无线交换机,交换机可以级联并于路由器相连,比如图中的校园网也是一个网间网,有局域网也有广域网,路由器将各个网络互联起来,整个互联网也是一个网间网即网络的网络,因此一个分组从源主机到目的主机可能穿过多个网络,为了区分标识各个网络接口,需要给主机和路由器的网络接口分配IP地址还要说明接口所处的网络即子网,标识接口所处的子网需要用到子网掩码,网络接口的IP地址和子网掩码按位相与就得到接口所处的子网地址。比如一个接口的IP地址为a.b.c.d,子网掩码为255.255.255.0,那它的子网地址就是a.b.c.0,子网地址中的网络前缀为a.b.c,主机号为0,对同一个子网中的各个网络接口必须指定相同的子网掩码,各IP地址还应具有相同的网络前缀,不同的主机号,而不同子网的主机IP地址应具有不同的网络前缀,那么如何配置网络接口的各个网络参数呢?对于路由器而言都是由管理员进行手工配置,而对于主机则是有两种方式即手工配置、自动配置。

在主机上自动配置网络接口的各个参数如图所示

自动获取

主机所在网络上必须有设备提供DHCP服务,对于家庭网络快带路由器可以兼职充当DHCP服务器,在配置快带路由器时需要激活路由器配置中的DHCP服务,事先配置好IP地址池,地址作用时长等,服务器会从地址池中选用当前未用的地址给申请自动获得IP地址的主机,地址池中的地址是临时地址。DHCP还支持固定地址,所谓固定地址只为特定的网络接口分配固定的IP地址。

需要强调的是DHCP为互联网主机(非路由器)提供配置参数:

  1. DHCP提供了一个在TCP/IP网络上从CHCP服务器传送配置参数给主机的框架。
  2. DHCP为主机分配网络地址:临时IP地址或固定地址,允许为特定的网络接口(MAC地址)分配固定的IP地址。

DHCP基于C/S模型,运行DHCP服务程序的主机(Server)向选择“自动获得IP设置”的主机(Client)传递配置参数。路由器常开启DHCP服务。

DHCP客户获得网络参数后方可与互联网上其他子网中的主机通信。

DHCP基于Bootstrap协议(BOOTP),增加了自动分配可重用网络地址功能和一些配置选项。

DHCP使用UDP作为传输层,DHCP Server和DHCP Client分别使用UDP端口号67和68

二、DHCP客户-服务器交互过程

我们通过实验获取DHCP交互数据,实验通过ADSL接入互联网的家庭网络上进行,测试主机为有线接入宽带路由器的笔记本电脑,路由器开启DHCP服务,并设置了分配临时地址需要的IP地址池和地址作用时间,地址池为192.168.0.100~192.168.0.199,作用时间为一周,具体实验步骤如下:

(仅启动本地连接)

  1. 手工配置IP地址等参数且主机可以正常上网
  2. 断开路由器电源
  3. 主机设置改为自动获得IP地址方式
  4. 使用Wireshark开始抓包,设置需要监听的网络接口,开始捕获
  5. 接通路由器电源,过一会停止抓包
  6. 过滤bootp,这样就只显示DHCP报文,这里我们可以看到DHCP报文的封装过程,DHCP报文先被封装在UDP报文中,UDP被封装在IP数据报中,IP数据报又被封装在以太帧中

从Wireshark捕获的分组我们可以看出DHCP客户和服务器完整的交互过程,依次包含4种报文。

  1. Discover
  2. offer
  3. Request
  4. ACK

如图

交互过程

图中左侧是DHCP路由器,也是DHCP服务器,右侧是测试主机也是DHCP客户

  1. 首先主机广播发送Discover报文,旨在发现DHCP服务器
  2. 然后服务器发送offer,表示愿意提供动态主机配置服务,因为主机提供了网络参数,如果本地网络有多个DHCP服务器,主机将收到多个offer。每个offer都有一个Server ID
  3. 第三步主机选择其中一个offer,发送确认报文Request,同时通知所有的服务器自己的选择
  4. 第四步被选服务器返回DHCP Acknowledge确认报文

我们可以看到IP地址和端口使用的细节,这里有一个问题是当主机还没有获得IP地址等网络参数之前是如何与本地网络上的其他主机进行通信呢?图例给我们的答案是,DHCP客户先使用IP地址全零的地址表示自己。

第二个问题是其他主机是如何与客户机进行通信呢?图中给出的是offer和acknowledge报文,封装它们的IP数据报的目的地址都是广播地址32位全1。

关于端口以Discover报文为例,源端口为DHCP客户,使用的是UDP端口68,目的端口是DHCP服务器使用的端口67,在该报文中显示yiaddr:0.0.0.0,表示此时客户方还没有分配IP地址,希望有服务器提供动态主机配置服务。

DHCP服务器发送offer报文,报文中显示yiappdr:192.168.0.100,Lease time:604800s(表示租用时间为一周),此外还给出了Server ID,在主机发送的Request报文中Server ID的值显示主机选择了哪一个offer。而Request报文中的Requested IP addr:192.168.0.100正是所选offer中的yiaddr

服务器发送的确认报文与offer报文仅仅是MessageType不同,一个是ACK一个offer

三、四个网络参数

无论是手工还是自动配置的,都需要这四个参数,DHCP服务器返回的不仅仅有分配的IP地址,还包括其他三个参数。通过确认报文的信息就会发现包含主机IP地址,子网掩码,默认网关,域名服务器IP地址,如果主机中已经手动添加了域名服务器DNS的IP地址,就以手动添加为主。

  1. 子网掩码

    主机在有了IP地址和子网掩码,在和其他主机通信时,用于了解目的主机和源主机是否在同一子网内,若是则可以直接交付,否则需要路由器的转发

  2. 第一跳路由器IP地址

    转发目的地为其他子网中主机的IP数据报

  3. DNS服务器的IP地址

    DNS服务器提供域名解析服务,不设置此项就无法使用域名访问互联网。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/18216.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

ElasticSearch8.7 搭配 SpringDataElasticSearch5.1 的使用

0. 前言 终于!终于!自个翻遍了网上的文章,加上对官网的文档和API的翻找,终于明白这玩意到底更新出了个啥出来! 本文章会带你了解,使用 SpringDataES5.1 对 ES8.7 的【新增、修改、删除、多条件查询、聚合】…

Kafka入门,分区的分配再平衡(二十)

分区的分配以及再平衡 1、kafka有四种主流的分区策略:Range,RoundRobin,Sticky,CooperativeSticky。可以通过配置参数partition.assignment.strategy,修改分区的分配策略。默认策略是RanageCooperativeSticky。Kafka可以同事使用多个分区分配策略。 参数描述heartb…

Pycharm设置Python文件页眉默认信息

次点击File->Settings->Editor->File and Code Templates->然后选择Python script. 后将下列代码复制到右边的框框中,然后选择apply应用,就可以啦 ##!/usr/bin/python3 # -*- coding: utf-8 -*- # Time : ${DATE} ${TIME} # Author : 作者…

【Django】列表页面的搜索功能

目的 页面列表增加多字段搜索显示查询结果 方案 分页显示搜索结果 效果 实现 列表页面 # list.html <div class"pull-left" style"margin-bottom: 10px"><form action"{% url api-search %}" method"get"><div …

MQ集群搭建

1.⾸先&#xff0c;克隆⼀台IP地址为192.168.230.132的虚拟机&#xff0c;然后参考章节的内 容&#xff0c;在该主机上安装RabbitMQ等环境。再加上之前的虚拟机&#xff0c;这样我们就准备好了两台Linux服 务器。 修改/etc/hosts映射⽂件。 vim /etc/hosts 3.两台Linux主机修改…

微软开源社区上线,能够给微软Win95等“上古系统”打补丁

日前一个基于社区的项目“Windows Update Restored”上线&#xff0c;据了解该项目的目的是为老系统重新提供对Windows Update的支持&#xff0c;可为 Windows 95 / NT 4.0/98(包括 SE)/ME/ 2000 SP2 等“上古时期”的微软操作系统提供升级补丁、修复 bug 或安全漏洞。 据悉&a…

k8s 就绪探针

【k8s 系列】k8s 学习二十&#xff0c;就绪探针 提起探针&#xff0c;不知兄dei 们是否有印象&#xff0c;之前我们分享过存活探针&#xff0c;分享存活探针是如何确保异常容器自动重启来保持应用程序的正常运行&#xff0c;感兴趣的可以查看文章 k8s 系列k8s 学习十七&#x…

masm32 链接问题

当我参考资料学习Windows环境下32位汇编时&#xff0c;编译倒没什么问题&#xff0c;可是链接就不对了。 网上也没找到解决办法&#xff0c;经过后来思考了一下&#xff0c;会不会是link.exe这个玩意有问题&#xff1f;比如有多个&#xff1f; 所以使用link的绝对路径试了一下…

【Hello mysql】 mysql的基本查询(二)

Mysql专栏&#xff1a;Mysql 本篇博客简介&#xff1a;介绍mysql的基本查询 mysql的基本查询&#xff08;二&#xff09; 将筛选出来的数据插入到数据库中&#xff08;insertselect&#xff09;聚合函数统计班级共有多少同学统计班级手机的qq号有多少统计本次考试去重的数学成绩…

【Linux】设置 命令 --help 帮助文件为中文

&#x1f341;博主简介 &#x1f3c5;云计算领域优质创作者   &#x1f3c5;华为云开发者社区专家博主   &#x1f3c5;阿里云开发者社区专家博主 &#x1f48a;交流社区&#xff1a;运维交流社区 欢迎大家的加入&#xff01; 文章目录 前言设置系统默认语言为中文安装man-…

Redis — 不仅仅是缓存

1*qIy3PMmEWNcD9Czh_21C8g.png Redis是一种快速、开源的内存键值&#xff08;NoSQL&#xff09;数据库&#xff0c;远远超越了缓存的功能。Redis使用RAM进行操作&#xff0c;提供亚毫秒级的响应时间&#xff0c;支持每秒数百万次请求。Redis主要用于缓存&#xff0c;但它也可以…

设置和使用DragGAN:搭建非官方的演示版

ragGAN的官方版还没有发布&#xff0c;但是已经有非官方版的实现了&#xff0c;我们看看如何使用。DragGAN不仅让GAN重新回到竞争轨道上&#xff0c;而且为GAN图像处理开辟了新的可能性。正式版本将于本月发布。但是现在已经可以在一个非官方的演示中试用这个新工具了 DragGAN …