设为首页 收藏本站
查看: 700|回复: 0

[经验分享] DHCP服务器原理及搭建过程

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2014-4-24 10:12:51 | 显示全部楼层 |阅读模式
DHCP:Dynamic Host Configure Protocol 动态主机配置协议
广播地址:FF-FF-FF-FF-FF-FF
广播IP 地址:255.255.255.0

DHCP的作用:
负责为客户机动态分配TCP/IP信息
IP地址
子网掩码
默认网关
首先DNS服务器(rhel6.3分配IP地址是从小到大)

为什么要采用DHCP:
减小管理员的工作量
减小输入错误的可能
避免IP冲突
提高了IP地址的利用率

DHCP服务的原理:
当IP地址不是固定绑定到哪台主机时,并且需要在客户机上先配置静态的ip,然后再改为动态获取,这时则为二个广播二个单播,否则都是广播
客户机请求IP地址(DHCPDiscover)广播
服务器响应请求(DHCPOffer)-->单播,发Offter之前,会发一个广播,确认所分配的IP地址是不是静态配置的
客户机选择IP地址(DHCPRequest)广播
服务器确认租约(DHCPAck)单播
续约的时候发的是request包,时间大概在租期的80%的时间,如果续租不到,就重新发discover包,重新到别的dhcp服务器获得ip地址
wKioL1NXcgqhCvcpAABEMbNUsU0157.jpg
安装dhcpd服务的过程:


当使用wireshark进行抓包时,如果想要看到DHCP四条动态时,则需要删除租约文件,并且重新刷新服务,目的是清除以前分配的IP地址
[iyunv@teacher dhcpd]# rm -rf  /var/lib/dhcpd/dhcpd.leases :服务器租约文件
service  dhcpd restart


[iyunv@station ~]# cat /var/lib/dhclient/dhclient-eth0.leases :客服机也是有租约文件
lease {
interface "eth0";
fixed-address 10.0.0.63;
filename "pxelinux.0";


[iyunv@station ~]# vim  /etc/dhcp/dhcpd.conf DHCP配置文件,设置相应的网段,掩码等相关信息
[iyunv@lichao520 dhcp]# cat dhcpd.conf
default-lease-time 600;
max-lease-time 7200;
log-facility local7;
subnet 10.5.5.0 netmask 255.255.255.0 {
range 10.5.5.26 10.5.5.130;
option domain-name-servers 8.8.8.8;
option domain-name "sxkeji.com.cn";
option routers 10.5.5.254;
}

host fantexi {
hardware ethernet 00:0c:29:11:22:ab;
fixed-address 10.5.5.88;
}


[iyunv@station ~]# cat /etc/sysconfig/dhcpd
在这个文件里可以设置在哪个网卡上提供DHCP服务,不写的话,开启了DHCP服务的网卡默认都是
# Command line options here
DHCPDARGS=


dhclient -r eth0:释放ip地址
dhclient  eth0 : 获得ip,要求网卡配置文件里采用dhcp方式获得ip

如果在/tec/dhcp/dhcp.d中定义了设备类型为local7,在进行dhcpd服务时可以在/var/log/messages和/var/log/boot.log查看相关信息

查看log,因为dhcpd.conf配置文件里定义的设备类型为local7,同时/etc/rsyslog.conf文件里规定的log文件的路径在/var/log/boot.log
dhcpd.conf
log-facility local7;
==
vim /etc/rsyslog.conf
# Save boot messages also to boot.log
local7.*                                                /var/log/boot.log

windows里的机器
ipconfig /release  :释放ip---》169.254开头的ip,说明已经没有有效ip了
ipconfig /renew    :获得ip


tail -f /var/log/boot.log 对dhcpd服务进行监听
May 30 10:43:50 lichao520 dhcpd: DHCPDISCOVER from 00:0c:29:11:22:ab (PC-20130503LURF) via eth0
May 30 10:43:51 lichao520 dhcpd: DHCPOFFER on 10.0.29.10 to 00:0c:29:11:22:ab (PC-20130503LURF) via eth0
May 30 10:43:51 lichao520 dhcpd: DHCPREQUEST for 10.0.29.10 (192.168.1.1) from 00:0c:29:11:22:ab (PC-20130503LURF) via eth0
May 30 10:43:51 lichao520 dhcpd: DHCPACK on 10.0.29.10 to 00:0c:29:11:22:ab (PC-20130503LURF) via eth0
May 30 10:43:57 lichao520 dhcpd: DHCPINFORM from 10.0.29.10 via eth0: not authoritative for subnet 10.0.29.0
May 30 10:44:00 lichao520 dhcpd: DHCPINFORM from 10.0.29.10 via eth0: not authoritative for subnet 10.0.29.0
====

netstat -antup|grep dhcp :查看监听端口
udp        0      0 0.0.0.0:67                  0.0.0.0:*                               4591/dhcpd         
n :numeric
a:all
p:program
t:tcp
u:udp
0.:67     表在所有的ip地址上67端口提供dhcp服务  


[iyunv@lichao520 ~]# chkconfig  --list dhcpd
dhcpd          0:关闭1:关闭2:关闭3:关闭4:关闭5:关闭6:关闭
[iyunv@lichao520 ~]# chkconfig dhcpd on   开机自动运行
[iyunv@lichao520 ~]# chkconfig  --list dhcpd
dhcpd          0:关闭1:关闭2:启用3:启用4:启用5:启用6:关闭

注意事项:
做dhcpd实验时
1.建议禁用NetworkManager服务
2.建议关闭防火墙 iptables -F
3.关闭selinux

service  NetworkManager stop   停止服务
chkconfig NetworkManager  off  设置开机不启动

vmnet0 ---》bridged
vmnet1--》hostonly
vmnet8--》nat

用rpm安装dhcpd
前提虚拟机设置为:hostonly和将虚拟机里的NAT取消
1)cd Packages/
2)rpm -ivh dhcp-4.1.1-31.P1.el6.i686.rpm
3)rpm -ql  dhcp|grep sample
/usr/share/doc/dhcp-4.1.1/dhcpd.conf.sample
4)cat /usr/share/doc/dhcp-4.1.1/dhcpd.conf.sample >>/etc/dhcp/dhcpd.conf
5)[iyunv@localhost dhcp]# cat /etc/dhcp/dhcpd.conf

default-lease-time 600;
max-lease-time 7200;
log-facility local7;
subnet 192.168.0.0 netmask 255.255.255.0 {
range 192.168.0.2  192.168.0.244;
option domain-name-servers 8.8.8.8;
option routers 192.168.0.1;
}

host passacaglia {
hardware ethernet 0:0:c0:5d:bd:95;
filename "vmunix.passacaglia";
server-name "toccata.fugue.com";
}

6)配置静态IP 地址:192.168.0.2
7)service network restart
8)ifconfig eth0
9)service dhcpd start
10)在windows下配置静态IP 地址,之后开启wireshark,之后将IP地址,改为自动获取



运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.iyunv.com/thread-18322-1-1.html 上篇帖子: ansible+corosync+pacemaker实现对web服务高可用 下篇帖子: centos coreseek 快速安装 服务器
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表