去皮卡多 发表于 2024-11-23 23:31:02

02 DHCP搭建

一、根本功能搭建(服务器+ 客户机)

服务器端

#关闭使用网卡自带的dhcp服务功能

#安装软件包
$ yum -y install dhcp
#生成配置文件
$ cp -a /usr/share/doc/dhcp-4.*.*/dhcpd.conf.sample/etc/dhcp/dhcpd.conf
#修改配置文件
$ vim /etc/dhcp/dhcpd.conf
        subnet 192.168.66.0 netmask 255.255.255.0{
                #设置地址范围(必填)
                range192.168.66.3 192.168.66.254;
      #设置DNS的地址
                option domain-name-servers 8.8.8.8;
                #设置DNS的域名
                option domain-name "kernel.com";
      #设置网关地址
                option routers192.168.66.1;
      #设置广播地址
                option broadcast-address 192.168.66.255;
                #设置租约时间
                default-lease-time 600;            
                max-lease-time 7200;
        }
#重启服务
$ systemctl start dhcpd
#验证服务开启状态
$ ss -antup | grep dhcp   #查看端口是否开启
$ ps aux | grep dhcp      #查看进程是否开启

客户端

#和dhcp服务器使用同一个虚拟网卡

#设置网卡、将获取IP地址的方式设置为dhcp
$ vim/etc/sysconfig/network-scripts/ifcfg-eth0
        BOOTPROTO=dhcp
        去掉IPADDR、NETWORK等       
# 重启网卡、查看获取的IP地址(已获取了一个IP,想重新获取也可以重启网卡)
$ systemctl restart network
或:ifdown ens33;ifup ens33;

#查看ip等资源是否获取到
$ ip addr               #查看是否获取到ip,且在分配的地址池里
$ route -n                #查看是否获取到网关
$ cat /etc/resolv.conf    #查看是否获取到dns

二、保留地点实验(服务器+ 客户机)

服务器端

$ vim /etc/dhcp/dhcpd.conf
        #需要有一个跟使用网卡同网段的地址池
        subnet 192.168.66.0 netmask 255.255.255.0{
                #设置地址范围(必填)
                range192.168.66.3 192.168.66.254;
      #设置网关地址
                option routers192.168.66.1;
        }
       
        host fantasia{
                #客户机的mac地址
                hardware ethernet mac地址;
      #固定分配给客户机的ip地址
                fixed-address IP地址;                  
    }
    host fantasia1{
                #客户机的mac地址
                hardware ethernet mac地址;
      #固定分配给客户机的ip地址
                fixed-address IP地址;                  
    }
$ systemctl restart dhcpd

#注:设置固定IP时,一定有一个同网络的subnet地址池分配
#注:该固定IP可以是地址池之外的IP地址
#注:若是要给多个mac地址固定分IP,需要些多个host块、且后面的名字不相同

#客户端测试成功后,可以看到租约信息:
$ cat /var/lib/dhcpd/dhcpd.leases
客户端

#和dhcp服务器使用同一个虚拟网卡

#设置网卡、将获取IP地址的方式设置为dhcp
$ vim/etc/sysconfig/network-scripts/ifcfg-eth0
        BOOTPROTO=dhcp
        去掉IPADDR、NETWORK等
# 重启网卡、查看获取的IP地址(已获取了一个IP,想重新获取也可以重启网卡)
$ systemctl restart network
或:ifdown ens33;ifup ens33;

#查看ip是否在地址池范围里
$ ip addr

三、超级作用域实验(服务器和路由器+ 客户机1+客户机2)

网络设置

dhcp服务器:vmnet1
        ens33 :192.168.66.100
        ens33:0 :192.168.77.100
客户机1:vmnet1
        ens33 : 自动获取
客户机2:vmnet1
        ens33 : 自动获取
DHCP服务器和路由器

#关闭使用网卡自带的dhcp服务功能

#为当前ens33网卡添加子网卡、设置该子网卡
$ cd /etc/sysconfig/network-scripts
$ cp -a ifcfg-ens33 ifcfg-ens33:0
$ vim ifcfg-ens33
        BOOTPROTO=static
        IPADDR=192.168.66.100
        PREFIX=24
$ vim ifcfg-ens33:0
        NAME=ens33:0
        DEVICE=ens33:0
        BOOTPROTO=static
        IPADDR=192.168.77.100
        PREFIX=24
$ systemctl restart network

#配置dhcp服务(注释掉其他实验地址池的设置、保留地址的设置)
#分配规则是先把第一个地址池的ip分配完、再分配第二个地址池
$ vim /etc/dhcp/dhcpd.conf
        shared-network public {
                subnet 192.168.66.0 netmask 255.255.255.0{
                        range 192.168.66.200 192.168.66.200;
                }
                subnet 192.168.77.0 netmask 255.255.255.0{
                        range192.168.77.110 192.168.77.120;
                }
        }
$ systemctl restart dhcpd

--------------------------------------------
#若使获取的两个网段ip的客户机相互ping通
#1.将dhcp服务器作为模拟路由,多网卡已设好,开启路由转发(根据自己装机的系统而定)
#CentOS6系统 或 Centos7字符系统:
$ vim /etc/sysctl.conf
        #修改0为1
        net.ipv4.ip_forward=1
#验证开启成功
$ sysctl -p   
------------------------------
#CentOS7桌面版(标准化):
$ vim /usr/lib/sysctl.d/50-default.conf
        #添加下面两行设置
        net.ipv4.conf.default.ip_forward = 1
        net.ipv4.conf.all.ip_forward = 1
#设置生效
$ reboot

#2.给两个客户机添加网关,通过设置dhcp服务使其自动获取
#dhcpd配置里把shared-network中subnet里的注释的option router打开
$ vim /etc/dhcp/dhcpd.conf
        shared-network public {
                subnet 192.168.66.0 netmask 255.255.255.0{
                        option routers 192.168.66.100;   #dhcp服务器ip
                        range 192.168.66.200 192.168.66.200;
                }
                subnet 192.168.77.0 netmask 255.255.255.0{
                        optionrouters192.168.77.100;    #dhcp服务器ip
                        range192.168.77.110 192.168.77.120;
                }
        }
$ systemctl restart dhcpd

#3.两个不同网段的客户机可以相互ping通

两台客户机重启网卡

#和dhcp服务器使用同一个虚拟网卡

#设置网卡、将获取IP地址的方式设置为dhcp
$ vim/etc/sysconfig/network-scripts/ifcfg-ens33
        BOOTPROTO=dhcp
        去掉IPADDR、NETWORK等
# 重启网卡、查看获取的IP地址(已获取了一个IP,想重新获取也可以重启网卡)
$ systemctl restart network
或:ifdown ens33;ifup ens33;

#查看ip是否在地址池范围里
$ ip addr

四、DHCP中继实验(DHCP服务器+DHCP中继和路由器+客户机)

网络设置

DHCP服务器:vmnet1
        ens33 : 192.168.66.77,网关为中继服务器上同网段的IP
DHCP中继器:
        ens33 :vmnet1, 192.168.66.100
        ens34 :vmnet2, 192.168.88.100
客户机:vmnet2
        ens33 : 自动获取
DHCP服务器

#关闭所有使用网卡自带的dhcp服务功能

#配置网卡信息
$ vim /etc/sysconfig/network-scripts/ifcfg-ens33
        BOOTPROTO=static
        IPADDR=192.168.66.77
        PREFIX=24
        GATEWAY=192.168.66.100   #设置成中继服务器的IP
$ systemctl restart network

#修改配置文件
$ vim /etc/dhcp/dhcpd.conf
        subnet 192.168.66.0 netmask 255.255.255.0{
                range 192.168.66.110 192.168.66.120;
        }
        subnet 192.168.88.0 netmask 255.255.255.0{
                range192.168.88.110 192.168.88.120;
        }
$ systemctl restart dhcpd

DHCP中继服务器

#配置两个网卡、配置不同网段的IP地址,不用开路由转发
$ vim /etc/sysconfig/network-scripts/ifcfg-ens33
        BOOTPROTO=static
        IPADDR=192.168.66.100
        PREFIX=24
$ vim /etc/sysconfig/network-scripts/ifcfg-ens34
        BOOTPROTO=static
        IPADDR=192.168.88.100
        PREFIX=24
$ systemctl restart network

#安装dhcp软件
$ yum -y install dhcp
#指定作为中继的DHCP服务器IP
$ dhcrelay DHCP服务器IP
#查看开启的结果
$ ss -tulnp | grep dhcrelay


-------------------------------
#若使两个客户机(vmnet1和vmnet2自动获取ip的主机)互相通信
#步骤同上个实验:中继器作为模拟路由、在dhcp服务中分别为2个subnet设置中继器ip做为网关

客户机

#和dhcp服务器的外网使用同一个虚拟网卡,关掉网卡自带的dhcp服务器
#设置网卡、将获取IP地址的方式设置为dhcp
$ vim/etc/sysconfig/network-scripts/ifcfg-ens33
        BOOTPROTO=dhcp
        去掉IPADDR、NETWORK等
# 重启网卡、查看获取的IP地址(已获取了一个IP,想重新获取也可以重启网卡)
$ systemctl restart network
或:ifdown ens33;ifup ens33;
#查看ip是否在地址池范围里
$ ip addr


免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
页: [1]
查看完整版本: 02 DHCP搭建