目录
一、DHCP介绍
- DHCP(Dynamic Host Configuration Protocol,动态主机配置协议),被应用在局域网环境中, 主要作用是集中的管理、分配IP地址,使网络环境中的主机动态的获得IP地址、Gateway 地址、DNS服务器地址等信息,并能够提升地址的使用率。由于DHCP是一个UDP协议,所 以运行起来更加高效。
- DHCP协议采用客户端/服务器模型(C/S模型),服务端可以为客户端提供IP、掩码、网关、主 机名、DNS等信息。客户端只需将IP获得方式设置为自动获取即可。
- 目前可以提供DHCP服务的设备有很多,比如:
(1)DHCP服务器(windows server、linux) (2)硬件路由器 (3)家用宽带路由
使用DHCP的优点:
1)傻瓜式接入:用户只需懂得插网线到电脑,或者输入WiFi密码接入网络即可实现联网
2)IP高效利用:及时回收IP机制,保证IP的高利用性,特别是对IP不足的网络
3)避免IP冲突:避免IP冲突,保证网络的高效利用,保证公司员工及临时人员高效工作
4)降低了公司网络管理员的工作量,提升了工作效率
二、DHCP涉及的常见术语
- 作用域:一个完整的IP地址段,DHCP根据作用域来管理网络的分布、IP地址的分配及其他配置参数。
- 超级作用域:用于管理处于同一个物理网络中的多个逻辑子网段,它包含了可以统一管理的作用域列表。
- 排除范围:把作用域中的某些IP地址排除,确保这些IP地址不会分配给DHCP客户端。
- 地址池:在定义了DHCP的作用域并应用了排除范围后,剩余的用来动态分配给客户端的IP地址范围。
- 租约:DHCP客户端能够使用动态分配的IP地址时间。
- 预约:保证网络中的特定设备总是获取到相同的IP地址。
三、关闭防火墙和selinux
1.关闭防火墙
[root@DHCP ~]# systemctl stop firewalld.service
# stop 停止当前服务
[root@DHCP ~]# systemctl disable firewalld.service
# disable 关闭开机自启
[root@DHCP ~]# systemctl status firewalld.service
# 查看防火墙状态
2.关闭禁止selinux
[root@DHCP ~]# vim /etc/selinux/config
将“enforcing”修改为“disable”,重启虚机生效
[root@DHCP ~]# getenforce
# 显示SELinux的状态
四、DHCP安装和配置本地软件仓库
[root@DHCP ~]# dnf -y install dhcp-server
# 开始配置软件仓库
# 1.把光盘设备中的系统镜像挂载到/media/cdrom目录
[root@DHCP ~]# mkdir -p /media/cdrom
[root@DHCP ~]# mount /dev/cdrom /media/cdrom/
# 2.为了能够让软件仓库一直为用户提供服务,需将系统镜像文件的挂载信息写入到/etc/fstab文件中,以保证万无一失
[root@DHCP ~]# vim /etc/fstab
# 添加下面代码:
/dev/cdrom /media/cdrom iso9660 defaults 0 0
[root@DHCP ~]# mount -a
#上述文件信息不会立即生效,需要自动挂载
# 3.创建软件仓库配置文件:RHEL 8需要配置两个软件仓库,缺一不可
[root@DHCP ~]# vim /etc/yum.repos.d/rhel8.repo
输入如下信息:
[BaseOS] #仓库名称,具有唯一性
name=BaseOS
baseurl=file:///media/cdrom/BaseOS #软件包的获取方式,也是本地文件(则需要在后面添加file参数),也可以使用FTP或HTTP下载
enabled=1 # 设置此源是否可用,1位可用,0为禁用
gpgcheck=0 # 设置此源是否校验文件,1位校验,0为不校验
[AppStream]
name=AppStream
baseurl=file:///media/cdrom/AppStream
enabled=1
gpgcheck=0
# 使用下面指令检查软件仓库是否已经可用
[root@DHCP ~]# yum -y install httpd
安装DHCP时报错,提示“没有启用的仓库”
则需要配置软件仓库:
[root@DHCP ~]# df -Th
# 查看盘空间的使用量情况,找到镜像挂载目录
-T 输出时显示文件系统类型
-h 以容易阅读的方式显示
如果查不到信息,确保设备状态两个勾选,如果还没有就取消再勾选即可。
再重新安装DHCP即可。
五、查看配置文件
[root@DHCP ~]# cat /etc/dhcp/dhcpd.conf
默认情况下,dhcp服务并没有提供配置文件,只是提供了一个demo,存放在/usr/share/doc/dhcp-server/目录下,我们将demo文件拷贝到/etc/dhcp/dhcpd.conf中。
[root@DHCP ~]# cp /usr/share/doc/dhcp-server/dhcpd.conf.example /etc/dhcp/dhcpd.conf
下面的案例将会在后面的实验中提及说明,本次部署不需要修改,默认即可。
[root@zutuanxue ~]# cat /etc/dhcp/dhcpd.conf
# DHCP服务配置文件分为全局配置和作用域配置,很好区分:subnet里的就是作用域 不在subnet里面的就是全局设置。
# dhcpd.conf
#DNS全局选项,指定DNS服务器的地址,可以是IP,也可以是域名。
# option definitions common to all supported networks...
# 定义DNS的域名
option domain-name "example.org";
#具体的DNS服务器地址
option domain-name-servers ns1.example.org, ns2.example.org;
#默认租约为600s
default-lease-time 600;
#最大租约为7200s,客户机会在default-lease-time快到期时向服务器续租,如果此时客户机死机/重启,而默认租约时间到期了,服务器并不会立即回收IP地址,而是等到最大租约时间到期,客户机还没有过来续约,才会回收IP地址。
max-lease-time 7200;
#动态DNS更新方式(none:不支持动态更新、interim:互动更新模式、ad-hoc:特殊更新模式)
# Use this to enble / disable dynamic dns updates globally.
#ddns-update-style none;
#如果该DHCP服务器是本地官方DHCP就将此选项打开,避免其他DHCP服务器的干扰。
#当一个客户端试图获得一个不是该DHCP服务器分配的IP信息,DHCP将发送一个拒绝消息,而不会等待请求超时。当请求被拒绝,客户端会重新向当前DHCP发送IP请求获得新地址。保证IP是自己发出去的
# If this DHCP server is the official DHCP server for the local
# network, the authoritative directive should be uncommented.
#authoritative;
# 日志级别
log-facility local7;
#作用域相关设置指令
#subnet 定义一个作用域
#netmask 定义作用域的掩码
#range 允许发放的IP范围
#option routers 指定网关地址
#option domain-name-servers 指定DNS服务器地址
#option broadcast-address 广播地址
#案例:定义一个作用域 网段为10.152.187.0 掩码为255.255.255.0
#此作用域不提供任何服务
subnet 10.152.187.0 netmask 255.255.255.0 {
}
# This is a very basic subnet declaration.
#案例:定义一个基本的作用域
#网段10.254.239.0 掩码255.255.255.224
#分发范围10.254.239.10-20
#网关为rtr-239-0-1.example.org, rtr-239-0-2.example.org
subnet 10.254.239.0 netmask 255.255.255.224 {
range 10.254.239.10 10.254.239.20;
option routers rtr-239-0-1.example.org, rtr-239-0-2.example.org;
}
# This declaration allows BOOTP clients to get dynamic addresses,
# which we don't really recommend.
#案例:允许采用bootp协议的客户端动态获得地址
#bootp DHCP的前身
#BOOTP用于无盘工作站的局域网中,可以让无盘工作站从一个中心服务器上获得IP地址。通过BOOTP协议可以为局域网中的无盘工作站分配动态IP地址,
#这样就不需要管理员去为每个用户去设置静态IP地址。
subnet 10.254.239.32 netmask 255.255.255.224 {
range dynamic-bootp 10.254.239.40 10.254.239.60;
option broadcast-address 10.254.239.31;
option routers rtr-239-32-1.example.org;
}
#案例:一个简单的作用域案例
# A slightly different configuration for an internal subnet.
subnet 10.5.5.0 netmask 255.255.255.224 {
range 10.5.5.26 10.5.5.30;
option domain-name-servers ns1.internal.example.org;
option domain-name "internal.example.org";
option routers 10.5.5.1;
option broadcast-address 10.5.5.31;
default-lease-time 600;
max-lease-time 7200;
}
# Hosts which require special configuration options can be listed in
# host statements. If no address is specified, the address will be
# allocated dynamically (if possible), but the host-specific information
# will still come from the host declaration.
#
#保留地址:可以将指定的IP分发给指定的机器,根据网卡的MAC地址来做触发
#host: 启用保留。
#hardware:指定客户端的mac地址
#filename:指定文件名
#server-name:指定下一跳服务器地址
#fixed-address: 指定保留IP地址
#
#
#案例:这个案例中分发给客户端的不是IP地址信息,而是告诉客户端去找toccata.fugue.com服务器,并且下载vmunix.passacaglia文件
host passacaglia {
hardware ethernet 0:0:c0:5d:bd:95;
filename "vmunix.passacaglia";
server-name "toccata.fugue.com";
}
# Fixed IP addresses can also be specified for hosts. These addresses
# should not also be listed as being available for dynamic assignment.
# Hosts for which fixed IP addresses have been specified can boot using
# BOOTP or DHCP. Hosts for which no fixed address is specified can only
# be booted with DHCP, unless there is an address range on the subnet
# to which a BOOTP client is connected which has the dynamic-bootp flag
# set.
# 案例:保留地址,将指定IP(fantasia.fugue.com对应的IP)分给指定客户端网卡(MAC:08:00:07:26:c0:a5)
host fantasia {
hardware ethernet 08:00:07:26:c0:a5;
fixed-address fantasia.fugue.com;
}
#超级作用域
#超级作用域是DHCP服务中的一种管理功能,使用超级作用域,可以将多个作用域组合为单个管理实体。
# You can declare a class of clients and then do address allocation
# based on that. The example below shows a case where all clients
# in a certain class get addresses on the 10.17.224/24 subnet, and all
# other clients get addresses on the 10.0.29/24 subnet.
#在局域网中,可以配置策略根据各个机器的具体信息分配IP地址和其他的网络参数,客户机的具体信息:客户机能够给dhcp服务提供的信息由有两个,
#第一个就是网卡的dhcp-client-identifier(mac地址),
#第二个就是设备的vendor-class-identifier。
#管理员可以根据这两个信息给不同的机器分组。
#案例:
#按client某种类型分组DHCP,而不是按物理接口网段
#例子: SUNW 分配地址段10.17.224.0/24
# 非SUNW的主机,分配地址段10.0.29.0/24
#定义一个dhcp类:foo
#request广播中vendor-class-identifier字段对应的值前四个字节如果是"SUNW",则视合法客户端.
class "foo" {
match if substring (option vendor-class-identifier, 0, 4) = "SUNW";
}
#定义一个超级作用域: 224-29
shared-network 224-29 {
#定义第一个作用域
subnet 10.17.224.0 netmask 255.255.255.0 {
option routers rtr-224.example.org;
}
#定义第二个作用域
subnet 10.0.29.0 netmask 255.255.255.0 {
option routers rtr-29.example.org;
}
#关连池,如果客户端匹配foo类,将获得该池地址
pool {
allow members of "foo";
range 10.17.224.10 10.17.224.250;
}
#关连池,如果客户端配置foo类,则拒绝获得该段地址
pool {
deny members of "foo";
range 10.0.29.10 10.0.29.230;
}
}
五、DHCP启动
需要在配置文件中添加一个本机网段的作用域,才会启动DHCP成功:
[root@DHCP ~]# systemctl enable dhcpd
#设置开机自启
[root@DHCP ~]# systemctl start dhcpd
#启动服务
[root@DHCP ~]# ps -ef | grep dhcpd
#查看进程
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/74674.html