CentOS 7实现DNS+DHCP动态更新详解
windows域里有一个功能,dhcp把新分发的ip数据发给DNS服务器,这样只要知道一个人的电脑名字就可以很方便的远程。
linux当然也能很好的实现类似的功能。man 5 dhcpd.conf 有详细描述。
昨天运维帮组织线下的沙龙,又拍云的运维总监邵海杨先生分享了一句“千金难买早知道”。是啊,就在实现动态更新的功能上,在网上找了不少博客,照着做又遇到各种问题,最后不不知道到底什么原理实现的。早知道认真看一下man,问题早解决了,对实现的原理也理解得深些。所以,在这个信息爆炸的时代,很多时候真的互联网没有让人更聪明,反而大量的信息经常把人淹没了。技术,还是需要静下心来去钻研的。
dhcp和dns的基本配置资料比较完善,此处不再赘述。有心的朋友认真看一下man 5 dhcpd.conf,瞧一眼下面配置中标红的部分,相信就能搞定了。
另外分享一个dns chroot的流程,先安装 bind,调通named,然后再安装bind-chroot
执行/usr/libexec/setup-named-chroot.sh /var/named/chroot on
停用named,启用named-chroot即可
systemctl disabled named ; systemctl stop named
systemctl enable named-chroot;systemctl start named-chroot
[root@pxe ~]# cat /etc/dhcp/dhcpd.conf
ddns-update-style interim;
ddns-updates on;
do-forward-updates on;
allow client-updates;
allow bootp;
allow booting;
#allow client-updates;
option space Cisco_LWAPP_AP;
option Cisco_LWAPP_AP.server-address code 241 = array of ip-address;
option space pxelinux;
option pxelinux.magic code 208 = string;
option pxelinux.configfile code 209 = text;
option pxelinux.pathprefix code 210 = text;
option pxelinux.reboottime code 211 = unsigned integer 32;
option architecture-type code 93 = unsigned integer 16;
subnet 192.168.1.0 netmask 255.255.255.0 {
authoritative;
option routers 192.168.1.1;
option subnet-mask 255.255.255.0;
option broadcast-address 192.168.1.255;
option domain-name "it.lab";
option domain-name-servers 192.168.1.200;
range dynamic-bootp 192.168.1.100 192.168.1.199;
key SEC_DDNS {
algorithm hmac-md5;
secret 7ObhTIhKeDFMR2SbbS5s8A==;
};
ddns-domainname "it.lab";
zone it.lab.{
primary 192.168.1.200;
key SEC_DDNS;
}
zone 1.168.192.in-addr.arpa.{
primary 192.168.1.200;
key SEC_DDNS;
}
default-lease-time 600;
max-lease-time 7200;
class "pxeclients" {
match if substring (option vendor-class-identifier, 0, 9) = "PXEClient";
next-server 192.168.1.200;
if option architecture-type = 00:07 {
filename "uefi/syslinux.efi"; }
else {
filename "bios/pxelinux.0"; }
#filename "pxelinux.0"; }
}
}
[root@pxe ~]# cat /etc/named.conf
//
// named.conf
//
// Provided by Red Hat bind package to configure the ISC BIND named(8) DNS
// server as a caching only nameserver (as a localhost DNS resolver only).
//
// See /usr/share/doc/bind*/sample/ for example named configuration files.
//
options {
listen-on port 53 { 127.0.0.1;192.168.1.200; };
listen-on-v6 port 53 { ::1; };
directory "/var/named";
dump-file "/var/named/data/cache_dump.db";
statistics-file "/var/named/data/named_stats.txt";
memstatistics-file "/var/named/data/named_mem_stats.txt";
allow-query { any;};
/*
- If you are building an AUTHORITATIVE DNS server, do NOT enable recursion.
- If you are building a RECURSIVE (caching) DNS server, you need to enable
recursion.
- If your recursive DNS server has a public IP address, you MUST enable access
control to limit queries to your legitimate users. Failing to do so will
cause your server to become part of large scale DNS amplification
attacks. Implementing BCP38 within your network would greatly
reduce such attack surface
*/
recursion no;
dnssec-enable yes;
dnssec-validation yes;
dnssec-lookaside auto;
/* Path to ISC DLV key */
bindkeys-file "/etc/named.iscdlv.key";
managed-keys-directory "/var/named/dynamic";
pid-file "/run/named/named.pid";
session-keyfile "/run/named/session.key";
};
logging {
channel default_debug {
file "data/named.run";
severity dynamic;
};
};
zone "." IN {
type hint;
file "named.ca";
};
include "/etc/named.rfc1912.zones";
include "/etc/named.root.key";
key SEC_DDNS {
algorithm hmac-md5;
secret 7ObhTIhKeDFMR2SbbS5s8A==;
};
zone "it.lab" IN {
type master;
file "it.lab.forward";
allow-update { key SEC_DDNS ; };
};
zone "1.168.192.in-addr.arpa" IN {
type master;
file "1.168.192.reverse";
allow-update { key SEC_DDNS ; };
};
互相保可以保多少大病
互相保可以保多少大病,互相保可以保100种大病,包括恶性肿瘤、急性心肌梗塞、严重脑中风后遗症、重大器官移植术或者造血干细胞移植术、开胸进行的冠状动脉搭桥术(冠状动脉旁路移植术)、终末期肾病(慢(0)人阅读时间:2023-10-19met20与met20pro区别(met20 pro价格)
met20与met20pro区别,met20与met20pro区别是:1、设计方面,无论是Mate 20 还是Mate 20 Pro,机身正面都不会有什么特别惊喜之处,因为设计上都与今年的其他旗舰产品没有太大的区别,Maote 20是美人尖或水(0)人阅读时间:2023-10-19micro和typec区别(micro是什么接口)
micro和typec区别,micro和typec区别是:(0)人阅读时间:2023-10-19solidworks尺寸 solidworks尺寸标注
solidworks尺寸,solidworks查看尺寸的方法如下:1、打开solidworks软件。2、打开要标注的工程图。3、点击顶端“草图”工具栏中的“智能尺寸”。4、用鼠标左键开始对工程图 中的相应位置进行(0)人阅读时间:2023-10-19互相保可以保多少大病
互相保可以保多少大病,互相保可以保100种大病,包括恶性肿瘤、急性心肌梗塞、严重脑中风后遗症、重大器官移植术或者造血干细胞移植术、开胸进行的冠状动脉搭桥术(冠状动脉旁路移植术)、终末期肾病(慢..2023-10-19met20与met20pro区别(met20 pro价格)
met20与met20pro区别,met20与met20pro区别是:1、设计方面,无论是Mate 20 还是Mate 20 Pro,机身正面都不会有什么特别惊喜之处,因为设计上都与今年的其他旗舰产品没有太大的区别,Maote 20是美人尖或水..2023-10-19micro和typec区别(micro是什么接口)
micro和typec区别,micro和typec区别是:..2023-10-19solidworks尺寸 solidworks尺寸标注
solidworks尺寸,solidworks查看尺寸的方法如下:1、打开solidworks软件。2、打开要标注的工程图。3、点击顶端“草图”工具栏中的“智能尺寸”。4、用鼠标左键开始对工程图 中的相应位置进行..2023-10-19