dhcp(dynamic host configuration protocol)是一个网络协议,它使得服务器能从预定义的 ip 池中为网络中的客户端节点自动分配 ip 地址并提供其它相关的网络配置参数。
这意味着每次客户端节点启动(连接到网络)的时候,它都会获得一个和从不改变的“静态” ip 地址相反的“动态” ip 地址。dhcp 服务器给 dhcp 客户端分配 ip 地址称为“租约”,租约时间随客户端需要的连接时间或 dhcp 的配置而异。
在这篇指南中,我们会介绍如何在 centos/rhel 和 fedora 发行版中安装和配置 dhcp 服务。
设置测试环境
本次安装中我们使用如下的测试环境:
dhcp 服务器 - centos 7
dhcp 客户端 - fedora 25 和 ubuntu 16.04
dhcp 如何工作?
在进入下一步之前,让我们首先了解一下 dhcp 的工作流程:
当已连接到网络的客户端计算机(配置为使用 dhcp)启动时,它会发送一个 dhcpdiscover 消息到 dhcp 服务器。
当 dhcp 服务器接收到 dhcpdiscover 请求消息时,它会回复一个 dhcpoffer 消息。
客户端收到 dhcpoffer 消息后,它再发送给服务器一个 dhcprequest 消息,表示客户端已准备好获取 dhcpoffer 消息中提供的网络配置。
最后,dhcp 服务器收到客户端的 dhcprequest 消息,并回复 dhcpack 消息,表示允许客户端使用分配给它的 ip 地址。
第一步:在 centos 上安装 dhcp 服务
1、安装 dhcp 服务非常简单,只需要运行下面的命令即可。
$ yum -y install dhcp
重要:假如系统中有多个网卡,但你想只在其中一个网卡上启用 dhcp 服务,可以按照下面的步骤在该网卡上启用 dhcp 服务。
2、 打开文件 /etc/sysconfig/dhcpd,将指定网卡的名称添加到 dhcpdargs 列表,假如网卡名称为 eth0,则添加:
dhcpdargs=eth0
保存文件并退出 。
第二步:在 centos 上配置 dhcp 服务
3、 对于初学者来说,配置 dhcp 服务的第一步是创建 dhcpd.conf 配置文件,dhcp 主要配置文件一般是 /etc/dhcp/dhcpd.conf(默认情况下该文件为空),该文件保存了发送给客户端的所有网络信息。
但是,有一个样例配置文件 /usr/share/doc/dhcp*/dhcpd.conf.sample,这是配置 dhcp 服务的良好开始。
dhcp 配置文件中定义了两种类型的语句:
参数 - 说明如何执行任务、是否执行任务、或者给 dhcp 客户端发送什么网络配置选项。
声明 - 指定网络拓扑、定义客户端、提供客户端地址、或将一组参数应用于一组声明。
因此,首先复制示例配置文件为主配置文件:
$ cp /usr/share/doc/dhcp-4.2.5/dhcpd.conf.example /etc/dhcp/dhcpd.conf
4、 然后,打开主配置文件并定义你的 dhcp 服务选项:
$ vi /etc/dhcp/dhcpd.conf
首先在文件开头设置以下应用于全部子网的全局参数(注意要使用你实际场景中的值):
option domain-name "tecmint.lan";
option domain-name-servers ns1.tecmint.lan, ns2.tecmint.lan;
default-lease-time 3600;
max-lease-time 7200;
authoritative;
5、 然后,定义一个子网;在这个事例中,我们会为 192.168.56.0/24 局域网配置 dhcp(注意使用你实际场景中的值):
subnet 192.168.56.0 netmask 255.255.255.0 {
option routers 192.168.56.1;
option subnet-mask 255.255.255.0;
option domain-search "tecmint.lan";
option domain-name-servers 192.168.56.1;
range 192.168.56.10 192.168.56.100;
range 192.168.56.120 192.168.56.200;
}
第三步:为 dhcp 客户端分配静态 ip
只需要在 /etc/dhcp/dhcpd.conf 文件中定义下面的部分,其中你必须显式指定它的 mac 地址和打算分配的 ip,你就可以为网络中指定的客户端计算机分配一个静态 ip 地址:
host ubuntu-node {
hardware ethernet 00:f0:m4:6y:89:0g;
fixed-address 192.168.56.105;
host fedora-node {
hardware ethernet 00:4g:8h:13:8h:3a;
fixed-address 192.168.56.110;
保存文件并关闭。
注意:你可以使用下面的命令找到 linux 的 mac 地址。
$ ifconfig -a eth0 | grep hwaddr
6、 现在,使用下面的命令启动 dhcp 服务,并使在下次系统启动时自动启动:
---------- on centos/rhel 7 ----------
$ systemctl start dhcpd
$ systemctl enable dhcpd
---------- on centos/rhel 6 ----------
$ service dhcpd start
$ chkconfig dhcpd on
7、 另外,别忘了使用下面的命令允许 dhcp 服务通过防火墙(dhcpd 守护进程通过 udp 监听67号端口):
---------- on centos/rhel 7 ----------
$ firewall-cmd --add-service=dhcp --permanent
$ firewall-cmd --reload
$ iptables -a input -p tcp -m state --state new --dport 67 -j accept
$ service iptables save
第四步:配置 dhcp 客户端
8、 现在,你可以为网络中的客户端配置自动从 dhcp 服务器中获取 ip 地址。登录到客户端机器并按照下面的方式修改以太网接口的配置文件(注意网卡的名称和编号):
# vi /etc/sysconfig/network-scripts/ifcfg-eth0
添加下面的选项:
device=eth0
bootproto=dhcp
type=ethernet
onboot=yes
保存文件并退出。
9、 你也可以在桌面服务器中按照下面的截图(ubuntu 16.04桌面版)通过 gui 设置 method 为 automatic (dhcp)。
在客户端网络中设置 dhcp
10、 按照下面的命令重启网络服务(你也可以通过重启系统):
$ systemctl restart network
$ service network restart
到了这里,如果所有设置都是正确的,你的客户端就应该能自动从 dhcp 服务器中获取 ip 地址。
作者:aaron kili
来源:51cto