博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
DHCP + DNS (bind) == DDNS(转)
阅读量:2449 次
发布时间:2019-05-10

本文共 3223 字,大约阅读时间需要 10 分钟。

DHCP + DNS (bind) == DDNS(转)[@more@]

我们在办室的时候,有时会去访问别的机器,如果是在windows下,我们我数时候会用机器名去访问,因为netbios/wins会帮我们来把机器名转成IP的。下面给大家介绍一种用动态DNS来解析机器名的办法。不过,不是用的w2k的DDNS,而是用的Linux.

准备:一台(或两台)Linux服务器,用来做DHCP server和DNS server。也可以把它做成两台服务器。

安装:服务器的安装过程,请参考其它文档,记住把 dhcp 和 bind, bind-utils 装上就行了。

配置:

一、DHCP的配置:

配置DHCP server 时很简单,可以参考 /usr/share/doc/dhcp-x.xx/dhcpd.conf.sample来做。也可以先把这个文件cp 到 /etc/dhcpd.conf,然后根据自己的需要做适当修改。下面贴出我的一个/etc/dhcpd.conf,供大家参考:

代码:

ddns-update-style interim;

ignore client-updates;

key DHCP_UPDATER {

algorithm HMAC-MD5;

secret qhB++OR5yWo8BTXwk/m4ng;

};

zone bj.pnx. {

primary 127.0.0.1;

key DHCP_UPDATER;

}

zone 251.168.192.in-addr.arpa. {

primary 127.0.0.1;

key DHCP_UPDATER;

}

subnet 192.168.251.0 netmask 255.255.255.0 {

range 192.168.251.100 192.168.251.200;

# --- default gateway

option routers 192.168.251.254;

option subnet-mask 255.255.255.0;

# option nis-domain "domain.org";

option domain-name "bj.pnx";

option domain-name-servers 192.168.251.63,192.168.251.254;

# option time-offset 28800; # PRC Standard Time

# option ntp-servers 192.168.251.220;

# option netbios-name-servers 192.168.1.1;

# range dynamic-bootp 192.168.0.128 192.168.0.255;

default-lease-time 21600;

max-lease-time 43200;

}

几个要注意的地方:

1. "ddns-update-style"

这个就是动态DNS的更新方式,有几个选项,我用的是interim,可以用 man dhcpd.conf找到另外的几个选项。

2. "ignore client-updates"

这个选项是不允许客户机更新DNS记录。当然,也可能允许,但会有一点问题。

3. "key DHCP_UPDATER"

这个是更新DNS的KEY,是必须的。其中algorithm 后的是生成key的算法,key的生成是用 "dnssec-keygen -a HMAC-MD5 -b 128 -n USER DHCP_UPDATER"。

4. "zone"

要更新的zone,如果是本机就是DNS server,primay 就写127.0.0.1,要是其它机器是DNS server, 就写那台机器的IP。

别的都是一般DNS该有的了,要注意的是一定要有 range 那一行,不然就分不了IP啦。

配好以后,可以启动一下试试, service dhcpd start,如果没问题,把dhcpd改成开机就启动,chkconfig --level 2345 dhcpd on。

二、bind(named)的配置。

关于bind(named)配置的文章有很多了。这里只把与普通配置不同的地方写出来。

下面给我的named.conf供大家参考:

代码:

// generated by named-bootconf.pl

options {

directory "/var/named";

/*

* If there is a firewall between you and nameservers you want

* to talk to, you might need to uncomment the query-source

* directive below. Previous versions of BIND always asked

* questions using port 53, but BIND 8.1 uses an unprivileged

* port by default.

*/

// forwarders { 192.168.1.254; };

// query-source address * port 53;

};

//

// a caching only nameserver config

//

controls {

inet 127.0.0.1 allow { localhost; } keys { rndckey; };

};

key DHCP_UPDATER {

algorithm HMAC-MD5;

secret qhB++OR5yWo8BTXwk/m4ng;

};

zone "." IN {

type hint;

file "named.ca";

};

zone "localhost" IN {

type master;

file "localhost.zone";

allow-update { none; };

};

zone "0.0.127.in-addr.arpa" IN {

type master;

file "named.local";

allow-update { none; };

};

zone "1.168.192.in-addr.arpa" IN {

type master;

file "1.168.192.zone";

allow-update { key DHCP_UPDATER; };

};

zone "test.com" IN {

type master;

file "test.com";

allow-update { key DHCP_UPDATER; };

};

include "/etc/rndc.key";

其中多了的是

代码:

key DHCP_UPDATER {

algorithm HMAC-MD5;

secret qhB++OR5yWo8BTXwk/m4ng;

};

这就是更新dns要用的key,必须和dhcpd.conf里的一样。

还有就是每个 zone 都可以用 key 来update了。

这样就行了。然后启动一下试试吧。

你就可以ping 机器名来找你同事的机器了。

本人只在windows客户机上试验过,Linux好象会有一点问题。哪位有兴趣,共同研究一下

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/8225414/viewspace-945027/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/8225414/viewspace-945027/

你可能感兴趣的文章
python基础知识教程_通过此深入的视频课程学习Python基础知识
查看>>
maven开始spring_如何开始使用Maven
查看>>
unity第一人称射击游戏_建立自己的第一人称射击游戏:8小时Unity 3D GameDev教程
查看>>
何时在JavaScript中使用var vs let vs const
查看>>
chrome扩展程序_如何发布您的Chrome扩展程序
查看>>
java类生成json数据_如何用Java生成数据类
查看>>
python 2 不再维护_如何不再害怕Python
查看>>
适用于所有人的Nextjs-具有一些React的基础知识
查看>>
mac 释放空间_如何释放开发人员Mac上的空间
查看>>
这些是您应该知道的ES6中的功能
查看>>
idea非开源安装指南_最终的开源贡献指南
查看>>
sql编写代码规范_停止编写额外的代码-您可以用SQL代替
查看>>
2019年遥感图像稀疏表征_图片为:2019年网络最佳图像格式
查看>>
apache kafka_轻松实现Apache Kafka集成的考虑因素
查看>>
graphql_GraphQL简介:它如何工作以及如何使用
查看>>
javascript 分号_为什么显式分号在JavaScript中很重要
查看>>
2018年最新税收分类编码_这是我们在2018年推出的所有免费编码课程
查看>>
react hooks使用_如何使用React Hooks创建响应式固定数据表
查看>>
react mongodb_如何使用Socket.io,React,Node和MongoDB创建实时应用
查看>>
傻瓜神经网络:这个引人入胜的领域的快速入门
查看>>