DNS是域名系统(Domain Name System)的缩写,是因特网的一项核心服务,它能提供域名与IP地址之间对应关系的转换服务。
这样我们就可以更方便地去访问互联网了,不用去记住那一串IP数字。本文档主要是说明如何把一台CentOS主机配置成一个DNS
服务器,以便能提供域名解析服务。
(1) DNS服务器端配置
操作系统:CentOS 6.4
IP地址:172.16.1.4
DNS软件:Bind 9.8
测试域名:realhostip.com
作用:主要提供解析realhostip.com域名的服务
1. 安装bind
# yum install bind
# vi /etc/named.conf
[html] view plain copy
- //
- //named.conf
- //
- //ProvidedbyRedHatbindpackagetoconfiguretheISCBINDnamed(8)DNS
- //serverasacachingonlynameserver(asalocalhostDNSresolveronly).
- //
- //See/usr/share/doc/bind*/sample/forexamplenamedconfigurationfiles.
- //
- options{
- listen-onport53{any;};//开启监听端口53,接受任意IP连接
- listen-on-v6port53{::1;};//支持IPV6
- 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{0.0.0.0/0;};//允许任意IP查询
- recursionyes;
- dnssec-enableyes; //报错修改成on后成功
- dnssec-validationyes; //报错修改成on后成功
- dnssec-lookasideauto;
- /*PathtoISCDLVkey*/
- bindkeys-file"/etc/named.iscdlv.key";
- managed-keys-directory"/var/named/dynamic";
- };
- logging{
- channeldefault_debug{
- file"data/named.run";
- severitydynamic;
- };
- };
- zone"."IN{
- typehint;
- file"named.ca";
- };
- include"/etc/named.rfc1912.zones";//主要配置文件
- include"/etc/named.root.key";
3. 修改/etc/named.rfc1912.zones文件,添加realhostip.com的正向和反向区域
# vi /etc/ named.rfc1912.zones
[html] view plain copy
- //named.rfc1912.zones:
- //
- //ProvidedbyRedHatcaching-nameserverpackage
- //
- //ISCBINDnamedzoneconfigurationforzonesrecommendedby
- //RFC1912section4.1:localhostTLDsandaddresszones
- //andhttp://www.ietf.org/internet-drafts/draft-ietf-dnsop-default-local-zones-02.txt
- //(c)2007RWFranks
- //
- //See/usr/share/doc/bind*/sample/forexamplenamedconfigurationfiles.
- //
- zone"localhost.localdomain"IN{
- typemaster;
- file"named.localhost";
- allow-update{none;};
- };
- zone"localhost"IN{
- typemaster;
- file"named.localhost";
- allow-update{none;};
- };
- zone"1.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.ip6.arpa"IN{
- typemaster;
- file"named.loopback";
- allow-update{none;};
- };
- zone"1.0.0.127.in-addr.arpa"IN{
- typemaster;
- file"named.loopback";
- allow-update{none;};
- };
- zone"0.in-addr.arpa"IN{
- typemaster;
- file"named.empty";
- allow-update{none;};
- };
- //realhostip.com的正向区域
- zone"realhostip.com"IN{
- typemaster;
- file"named.realhostip.com";
- allow-update{none;};
- };
- //realhostip.com的反向区域
- zone"1.16.172.in-addr.arpa"IN{
- typemaster;
- file"172.16.1.arpa";
- allow-update{none;};
- };
这里需要注意的是,添加反向区域时,网络号要反过来写(网络号是IP地址与子网掩码进行与操作后的结果)。
例如,我现在配置的网络号172.16.1这个网段,那么它的反向区域是1.16.172.in-addr.arpa。区域里面的file
字段表明解析时的数据来源文件,接下来我们去创建named.realhostip.com和172.16.1.arpa文件。
4. 创建正向和反向区域资源文件
在配置named.conf时,指明的资源文件目录是/var/named,故先进入该目录。
# cd /var/named
# vi named.realhostip.com
[html] view plain copy
- $TTL1D
- @INSOArealhostip.com.rname.invalid.(
- 0;serial
- 1D;refresh
- 1H;retry
- 1W;expire
- 3H);minimum
- NS@
- A127.0.0.1
- AAAA::1
- 172-16-1-50INA172.16.1.50
- 172-16-1-51INA172.16.1.51
以上我添加了两条记录,其中172-16-1-50 IN A 172.16.1.50表明域名172-16-1-50.realhostip.com对应的IP地址为172.16.1.50。
如果需要添加多条,按此类似添加,留意realhostip.com后面的那个不起眼的点(.)。
# vi 172.16.1.arpa
[html] view plain copy
- $TTL1D
- @INSOArealhostip.com.rname.invalid.(
- 0;serial
- 1D;refresh
- 1H;retry
- 1W;expire
- 3H);minimum
- NS@
- AAAA::1
- 50PTR172-16-1-50.realhostip.com.
- 51PTR172-16-1-51.realhostip.com.
以上我也添加了两条记录,其中50PTR 172-16-1-50.realhostip.com表明IP地址172.16.1.50对应的
域名为172-16-1-50.realhostip.com。如果要添加多条,按此类似添加,留意realhostip.com后面的那个不起眼的点(.)。
5. 启动named服务
#service named start
至此,DNS服务器端的配置已完成,下面我们稍微配置一下客户端来测试我们的DNS服务器是否正常工作。
(2) 客户端配置
操作系统:windows和linux都可以,我这里是CentOS 6.4
IP地址:能够ping通DNS服务器的IP(172.16.1.4)都可以,我这里是172.16.1.104
作用:测试DNS服务器是否正常工作。
1. 安装bind-utils包,以便能使用nslookup、dig和host工具
yum install bind-utils
2. 修改DNS配置使用我们的DNS服务器
vi /etc/resolv.conf
[html] view plain copy
- nameserver172.16.1.4
- nameserver192.168.13.31
- nameserver172.16.1.1
如果是windows客户端,需要在本地连接属性里面修改,如下图:
resolv.conf文件中可能会有多个nameserver,必须把我们的DNS服务器放在所有nameserver的最前面,
这样当需要解析域名时,第一个使用的就是我们配置的DNS服务器,其它的都是候选项。
3. 正向解析测试,使用nslookup命令
#nslookup
[html] view plain copy
- >172-16-1-50.realhostip.com
- Server:172.16.1.4
- Address:172.16.1.4#53
- Name:172-16-1-50.realhostip.com
- Address:172.16.1.50
- >
- >172-16-1-51.realhostip.com
- Server:172.16.1.4
- Address:172.16.1.4#53
- Name:172-16-1-51.realhostip.com
- Address:172.16.1.51
- >
从结果可以看到,我们配置的两个域名都能成功解析,并且DNS服务器就是我们配置的那个服务器。
4. 反向解析,使用nslookup命令
#nslookup
[html] view plain copy
- >
- >172.16.1.51
- Server:172.16.1.4
- Address:172.16.1.4#53
- 51.1.16.172.in-addr.arpaname=172-16-1-51.realhostip.com.
- >
- >
- >172.16.1.50
- Server:172.16.1.4
- Address:172.16.1.4#53
- 50.1.16.172.in-addr.arpaname=172-16-1-50.realhostip.com.
- >
- >
从结果来看,可以正确解析我们的IP地址,并且DNS服务器就是我们配置的那个服务器。
5. 查看realhostip.com这个域名是哪个DNS服务器管理的,使用dig命令
# dig -t ns realhostip.com
[html] view plain copy
- ;<<>>DiG9.8.2rc1-RedHat-9.8.2-0.17.rc1.el6_4.6<<>>-tnsrealhostip.com
- ;;globaloptions:+cmd
- ;;Gotanswer:
- ;;->>HEADER<<-opcode:QUERY,status:NOERROR,id:37964
- ;;flags:qraardra;QUERY:1,ANSWER:1,AUTHORITY:0,ADDITIONAL:2
- ;;QUESTIONSECTION:
- ;realhostip.com.INNS
- ;;ANSWERSECTION:
- realhostip.com.86400INNSrealhostip.com.
- ;;ADDITIONALSECTION:
- realhostip.com.86400INA172.16.1.4
- realhostip.com.86400INAAAA::1
- ;;Querytime:1msec
- ;;SERVER:172.16.1.4#53(172.16.1.4)
- ;;WHEN:WedOct2314:15:222013
- ;;MSGSIZErcvd:90
6. 使用dig命令进行正向解析
# dig 172-16-1-50.realhostip.com
[html] view plain copy
- ;<<>>DiG9.8.2rc1-RedHat-9.8.2-0.17.rc1.el6_4.6<<>>172-16-1-50.realhostip.com
- ;;globaloptions:+cmd
- ;;Gotanswer:
- ;;->>HEADER<<-opcode:QUERY,id:21109
- ;;flags:qraardra;QUERY:1,AUTHORITY:1,ADDITIONAL:2
- ;;QUESTIONSECTION:
- ;172-16-1-50.realhostip.com.INA
- ;;ANSWERSECTION:
- 172-16-1-50.realhostip.com.86400INA172.16.1.50
- ;;AUTHORITYSECTION:
- realhostip.com.86400INNSrealhostip.com.
- ;;ADDITIONALSECTION:
- realhostip.com.86400INA172.16.1.4
- realhostip.com.86400INAAAA::1
- ;;Querytime:1msec
- ;;SERVER:172.16.1.4#53(172.16.1.4)
- ;;WHEN:WedOct2314:17:572013
- ;;MSGSIZErcvd:118
注意:
windows客户端上只有nslookup工具。
(3) 相关资料
[1] http://www.linuxidc.com/Linux/2012-03/56086.htm
[2] http://www.linuxidc.com/Linux/2013-07/87440.htm
[3] http://wenku.baidu.com/view/e7095ad7b14e852458fb57db.html
[4] http://www.jb51.cc/article/p-estzihxv-vw.html
[5] http://www.jb51.cc/article/p-vsxhpidp-np.html
[6] http://www.jb51.cc/article/p-cxkecfds-np.html
[7] http://www.jb51.cc/article/p-byfqgrkf-gy.html
[8] http://www.linuxdiyf.com/viewarticle.php?id=16156
[9] http://linux.chinaunix.net/techdoc/install/2007/10/25/970650.shtml