30.Linux DHCP 服务器

文章目录

Linux DHCP 服务器

简单回顾

在大型网络中,系统静态分配IP地址会面临问题:

  1. 确保不在多个系统上配置同一个IP地址
  2. 部署新系统通常需要人工手动分配IP地址

所以面对大型网络我们一般采用动态主机配置协议DHCP,提供自动分配网络参数的方法,例如IP地址,默认网关,DNS服务器和域或者NTP服务器。

DHCP有两种协议:

  • DHCPv4(用于IPv4网络)
  • DHCPv6(用于IPv6网络)

本章节我们来一起学习DHCPv4。

DHCP工作步骤

第一步:DHCP发现

客户端以广播 形式(目标地址为255.255.255.255)发送一个DHCP Discover数据包。

第二步:DHCP提供

DHCP服务器从自己的IP地址池中选出一个可用的IP地址,同样通过广播 (因为客户端还没有IP,无法直接回复)发送一个DHCP Offer数据包。这个包里包含了准备分配的IP地址、子网掩码、网关、DNS服务器地址等信息。

第三步:DHCP请求

客户端广播 发送一个DHCP Request数据包,里面包含了它选择的那个DHCP服务器的标识符和IP地址。这样做是为了通知所有DHCP服务器最终选择,让未被选中的服务器释放他们预留的IP地址。

第四步:DHCP确认

被选中的DHCP服务器发送一个DHCP ACK广播包。这个包包含了IP地址、租期以及所有网络配置参数的最终确认信息。

收到ACK后: 你的电脑就会应用这个IP地址和配置,然后就可以正常上网了。

部署DHCP服务器

安装DHCP软件包

bash 复制代码
[root@server ~ 17:00:44]# yum install -y dhcp

配置DHCP配置文件

dhcpd服务使用/etc/dhcp/dhcpd.conf配置文件。

首先看看配置文件内有没有模板

bash 复制代码
[root@server ~ 17:03:16]# cat /etc/dhcp/dhcpd.conf
#
# DHCP Server Configuration file.
#   see /usr/share/doc/dhcp*/dhcpd.conf.example
#   see dhcpd.conf(5) man page
#

可以看见文件提示配置文件的模板位置所在

我们将这个文件复制过来

bash 复制代码
[root@server ~ 17:03:16]# cp /usr/share/doc/dhcp*/dhcpd.conf.example /etc/dhcp/dhcpd.conf

进行修改配置文件

bash 复制代码
[root@server ~ 17:09:02]# vim /etc/dhcp/dhcpd.conf
# 配置域名
option domain-name "hxl.cloud";

# 配置 DNS 服务器
option domain-name-servers 223.5.5.5, 223.6.6.6;

# 默认租约时间
default-lease-time 600;

# 最大租约时间
max-lease-time 7200;

# 配置日志级别
log-facility local7;

# 配置 DHCP 池
subnet 10.1.8.0 netmask 255.255.255.0 {
  range 10.1.8.101 10.1.8.130;
  #option domain-name-servers ns1.internal.example.org;
  #option domain-name "internal.example.org";
  option routers 10.1.8.2;
  option broadcast-address 10.1.8.255;
  #default-lease-time 600;
  #max-lease-time 7200;
}

重新启动一下dhcpd服务

bash 复制代码
[root@server ~ 17:09:16]# systemctl restart dhcpd

部署客户端网络

为了测试DHCP功能,我们先给客户端添加一张新的网卡

并且关闭网络编辑器中自动的DHCP功能

先给新的网卡修改名字

bash 复制代码
[root@client ~ 17:16:41]# nmcli connection modify 有线连接\ 1 con-name ens37
[root@client ~ 17:17:04]# nmcli connection 
NAME   UUID                                  TYPE      DEVICE 
ens33  4dd56f90-92f5-486f-9055-ba5a4c2ff049  ethernet  ens33  
ens37  809b2329-c556-323b-8d49-bc4301b64b99  ethernet  --

给新网卡启动起来

bash 复制代码
[root@client ~ 17:18:58]# nmcli connection up ens37
连接已成功激活(D-Bus 活动路径:/org/freedesktop/NetworkManager/ActiveConnection/7)
[root@client ~ 17:19:07]# nmcli connection 
NAME   UUID                                  TYPE      DEVICE 
ens33  4dd56f90-92f5-486f-9055-ba5a4c2ff049  ethernet  ens33  
ens37  809b2329-c556-323b-8d49-bc4301b64b99  ethernet  ens37  
[root@client ~ 17:19:15]# ip -br a
lo               UNKNOWN        127.0.0.1/8 ::1/128 
ens33            UP             10.1.8.11/24 fe80::20c:29ff:fe55:a3e4/64 
ens37            UP             10.1.8.102/24 fe80::90d1:9eb1:331e:5089/64

我们在服务器端设置的地址池是.101~.130的地址,这里给我们分配到一个.102的IP地址,我们再给服务器端的配置再做一些修改,让服务器根据MAC地址配置固定IP

首先我们查看新网卡的MAC地址

bash 复制代码
[root@client ~ 17:28:58]# ip -br link 
lo               UNKNOWN        00:00:00:00:00:00 <LOOPBACK,UP,LOWER_UP> 
ens33            UP             00:0c:29:55:a3:e4 <BROADCAST,MULTICAST,UP,LOWER_UP> 
ens37            UP             00:0c:29:55:a3:ee <BROADCAST,MULTICAST,UP,LOWER_UP>

根据这个MAC地址,在/etc/dhcp/dhcpd.conf最后加上这样的配置

bash 复制代码
host client.hxl.cloud {
  hardware ethernet 00:0c:29:55:a3:ee;
  fixed-address 10.1.8.100 ;
}

这里我们设置.100的IP地址

重启服务端的dhcpd服务和客户端的网卡

bash 复制代码
# dhcp服务器
[root@server ~ 18:35:31]# systemctl restart dhcpd

# 客户端
[root@client ~ 18:32:48]# nmcli connection up  ens37
连接已成功激活(D-Bus 活动路径:/org/freedesktop/NetworkManager/ActiveConnection/9)
[root@client ~ 18:35:52]# ip -br a
lo               UNKNOWN        127.0.0.1/8 ::1/128 
ens33            UP             10.1.8.11/24 fe80::20c:29ff:fe55:a3e4/64 
ens37            UP             10.1.8.100/24 fe80::90d1:9eb1:331e:5089/64

可以发现,我们的新网卡地址变成了10.1.8.100,配置成功

相关推荐
兜兜转转了多少年6 分钟前
从脚本到系统:2026 年 AI 代理驱动的 Shell 自动化
运维·人工智能·自动化
深蓝海拓9 分钟前
PySide6,QCoreApplication::aboutToQuit与QtQore.qAddPostRoutine:退出前后的清理工作
笔记·python·qt·学习·pyqt
酒鼎10 分钟前
学习笔记(3)HTML5新特性(第2章)
笔记·学习·html5
.小墨迹37 分钟前
apollo学习之借道超车的速度规划
linux·c++·学习·算法·ubuntu
山岚的运维笔记1 小时前
SQL Server笔记 -- 第20章:TRY/CATCH
java·数据库·笔记·sql·microsoft·sqlserver
Gain_chance1 小时前
33-学习笔记尚硅谷数仓搭建-DWS层交易域用户粒度订单表分析及设计代码
数据库·数据仓库·hive·笔记·学习·datagrip
Lsir10110_1 小时前
【Linux】中断 —— 操作系统的运行基石
linux·运维·嵌入式硬件
hqyjzsb1 小时前
盲目用AI提效?当心陷入“工具奴”陷阱,效率不增反降
人工智能·学习·职场和发展·创业创新·学习方法·业界资讯·远程工作
Sheffield1 小时前
command和shell模块到底区别在哪?
linux·云计算·ansible
历程里程碑1 小时前
Linux20 : IO
linux·c语言·开发语言·数据结构·c++·算法