DHCP简单阐述及配置实现方法

DHCP是什么……

DHCP是Dynamic Host Configuration Protocol的缩写,它是TCP/IP协议簇中的一种,主要是用来给网络客户机分配动态的IP地址。 
其主要功能是: 
用于内部网络或网络服务供应商自动分配IP地址给用户 
用于内部网络管理员作为对所有电脑作中央管理的手段 
直接点就是,这些被分配的IP地址都是DHCP服务器预先保留的一个由多个地址组成的地址集,并且它们一般是一段连续的地址。

DHCP工作原理

动态主机设置协议(DHCP)是一种使网络管理员能够集中管理和自动分配IP网络地址的通信协议。在IP网络中,每个连接Internet的设备都需要分配唯一的IP地址。DHCP使网络管理员能从中心结点监控和分配IP地址。当某台计算机移到网络中的其它位置时,能自动收到新的IP地址。 
DHCP使用了租约的概念,或称为计算机IP地址的有效期。租用时间是不定的,主要取决于用户在某地连接Internet需要多久,这对于教育行业和其它用户频繁改变的环境是很实用的。通过较短的租期,DHCP能够在一个计算机比可用IP地址多的环境中动态地重新配置网络。DHCP支持为计算机分配静态地址,如需要永久性IP地址的Web服务器。 
DHCP和另一个网络IP管理协议BOOTP类似是DHCP的前身并且向后兼容。目前两种配置管理协议都得到了普遍使用。其中DHCP更为先进,某些操作系统如Windows NT/2000都带有DHCP服务器。DHCP或BOOTP客户端是装在计算机中的一个程序,这样就可以对其进行配置操作。

DHCP的简单工作流程

当DHCP客户端程序发出一个信息,要求一个动态的IP地址时,DHCP服务器会根据目前已经配置的地址,提供一个可供使用的IP地址和子网掩码给客户端,大致流程如… 
(1) 客户端向服务器端发出请求 //dhcp discover 
(2) 服务端要响应客户端的请求 //dhcp offer 
(3) 然后客户端要选择请求使用哪一项 //dhcp request 
(4)最后服务端进行最终确认 //dhcp ack 
注意:DHCP服务不可跨网段,不可跨越物理路由器,且整个过程都是广播的形式

DHCP中继

也叫DHCP Realy ,服务是面向服务端单播,面向客户端广播 
其功能就是帮忙把有DHCP服务的提供给另一个没有DHCP服务器的网络 
当然,用腿想都能想明白,自己家菜地不播种自己家的种子,难道你还给别人播种

DHCP的实现方法

DHCP的实现有两种,DHCP Relay与DHCP Server 
DHCP Relay的功能在某一复杂的网络中使用比较普遍,比方说大型酒店或者运营商,所以这里不过多说明。(如果你想深入了解,建议去学习Cisco的网络工程师课程)

实验准备环境

实验环境:基于Win平台搭建的VMware虚拟机实现 
准备主机两台:一台DHCP Server端,一台DHCP Client端 
配置网段地址以192.168.5.0/24 这个为例 
主机环境:Centos7.2_Server_x86_64

虚拟机的设置

运行两台虚拟机,把网络适配器修改为:自定义,特定虚拟网络。随便选择个网络,我这里用的是VMnet2,选好确定就可以。两台都是一样的 
指定一台当DHCP的Server端,地址是172.16.5.5/16,网关172.16.5.5 
另一台做DHCP客户端,网络适配器也选择自定义并且是VMnet2,这样就可以了接下来我们进行配置

DHCP的配置实现

在Centos7系统中我们直接用yum安装

安装后看它生成了哪些文件,我只贴上配置需要的文件
[root@node2 ~]# yum install dhcp
[root@node2 ~]# rpm -ql dhcp
dhcp-4.2.5-42.el7.centos.x86_64 //已安装
[root@node2 ~]# rpm -ql dhcp
/etc/dhcp/dhcpd.conf //这个是服务的配置文件路径
/usr/lib/systemd/system/dhcpd.service //这个是Unit服务文件路径
/usr/share/doc/dhcp-4.2.5/dhcpd.conf.example //这个是我们要参考的配置文件

拷贝参考文件到DHCP的配置文件目录下,给一个网段分配地址

[root@node2 ~]# cp -a /usr/share/doc/dhcp-4.2.5/dhcpd.conf.example /etc/dhcp/dhcpd.conf //拷贝参考文件直接覆盖dhcpd.conf文件
编辑dhcpd.conf文件
   vim /etc/dhcp/dhcpd.conf修改以下内容
# dhcpd.conf
#
# Sample configuration file for ISC dhcpd
option domain-name "glances.org";
option domain-name-servers 192.168.5.5,223.5.5.5;
option routers 192.168.5.5;
default-lease-time 600;
max-lease-time 7200;

subnet 192.168.5.0 netmask 255.255.255.0 {
   range 192.168.5.10 192.168.5.100;  
}
其它的都可以注释掉
   :.,$s/^[[:space:]]*[^#]/#/g
重启network服务
   systemctl restart network.service
重启dhcpd服务
   systemctl restart dhcpd.service
确保DHCP服务端UDP的67端口被监听 ss -tnul
测试:多启动几个客户端测试
服务端使用命令实时检测日志动态;tail -f /var/log/messages

给一个主机分配一个固定地址 Host fantasia项

# option definitions common to all supported networks...
option domain-name "glances.org";
option domain-name-servers 192.168.5.5,223.5.5.5;
option routers 192.168.5.5;
default-lease-time 600;
max-lease-time 7200;
# DHCP server to understand the network topology.
subnet 192.168.5.0 netmask 255.255.255.0 {
   range 192.168.5.10 192.168.5.100;  
}
Host fantasia { //名字可以随便写
hardware ethernet 00:0c:29:6c:3f:65; //给定网卡MAC地址
fixed-address 192.168.5.30; //对应的ip地址,须是地址池之外地址
}
重启dhcpd服务;systemctl restart dhcpd
实时检测地址分配状态;tail -f /var/log/messages
客户端使用dhcp命令行工具测试:dhclient -d (d是把任务调入前台执行)

其它的给一个共享网络配置地址,我们工作中应该使用的不多,所以不介绍。使用到直接再查看帮助就行。

这里特别要注意下

在配置DHCP服务当中,区域配置文件中所定义网关是有优先级的,要注意。 
全局配置;对所有配置生效,且此配置段中网关对全局有效。 
子网配置;仅对子网生效,且此配置段中网关优先于全局配置中的网关。 
主机配置;仅对一个主机生效,且此配置段中网关优先于全局配置中网关,也可以更改option项直接定义到你配置的子网区域中… 
共享网络;对共享网络下的所有网络有效

ARP与RARP

ARP与RARP在OSI参考模型中都是位于网络层。而且它的协议数据单元是封装在以太网帧中传送并且请求是以广播形式发送。 
简单点就是:ARP是IP地址解析为MAC地址,RARP是MAC地址解析为IP地址 
学名:ARP,即地址解析协议。RARP即反向地址转换协议 
先到这其它的再聊,预知详情,请自行Google……

原创文章,作者:51eA,如若转载,请注明出处:http://www.178linux.com/57477

(0)
51eA51eA
上一篇 2016-12-05
下一篇 2016-12-05

相关推荐

  • Man手册功能介绍

    Man:是Linux下的帮助指令,通过man指令可以查看Linux中的指令帮助、配置文件帮助和编程帮助等信息。 语法:man(选项)(参数) 选项: -a:在所有的man帮助手册中搜索 -f:等价于whatis指令,显示给定关键字的简短描述信息 -P:指定内容时使用分页程序 -M:指定man手册搜索的路径。 本地手册:/usr/share/man &nbsp…

    Linux干货 2016-10-17
  • 自建CA搭建SSL加密网站

    企业环境中,在安全级别要求较高的公司,经常需要搭建基于SSL加密传输的网站,使用https协议访问web站点,能大大提高网站的安全性。但构建https站点,需要用到证书。内部网站到互联网上申请费用不菲的证书显然不符合经济性。于是,自建内部CA成为我们的首选。 本文以两台服务器,分别扮演CA及Web网站的角色,详细论述自建CA搭建加密网站的过程。  …

    Linux干货 2016-07-29
  • bash的一些特性

    bash的字符串处理工具 字符串切片: ${var:offset:number} 取字符串的子串; 取字符串的最右侧的几个字符:${var: -length} 注意:冒号后必须有一个空白字符; 基于模式取子串; ${var#*word}: 其中word是指定的分隔符;功能:自左而右,查找var变量中所存储的字符串中,第一次出现word分隔符,删除字符串开头至…

    Linux干货 2016-08-24
  • week7

    1、创建一个10G分区,并格式为ext4文件系统; (1) 要求其block大小为2048, 预留空间百分比为2, 卷标为MYDATA, 默认挂载属性包含acl; (2) 挂载至/data/mydata目录,要求挂载时禁止程序自动运行,且不更新文件的访问时间戳; fdisk /dev/sdb  按提示创建出来10G分区 查看1:…

    Linux干货 2016-12-08
  • 20160810作业

    1、编写脚本/root/bin/systeminfo.sh,显示当前主机系统信息,包括主机名,IPv4地址,操作系统版本,内核版本,CPU型号,内存大小,硬盘大小。           2、编写脚本/root/bin/backup.sh,可实现每日将/etc/目录备份到/root…

    Linux干货 2016-08-12
  • 作业管理

    作业管理 ·Linux的作业控制:          前台作业:通过终端启动,且启动后一直占据终端;          后台作业:可通过终端启动,但启动后即转入后台运行(释放终端) ·如何让作业运行于…

    Linux干货 2016-09-11