1、DNS配置文件 
/etc/hosts   这个是最早的 hostname 对应 IP 的档案;

/etc/resolv.conf :这个重要!就是 ISP 的 DNS 服务器 IP 记录处;

/etc/nsswitch.conf:这个档案则是在『决定』先要使用 /etc/hosts 还是 
/etc/resolv.conf 的设定!

一般而言, Linux 的预设主机名与 IP 的对应搜寻都以 /etc/hosts 为优先,

2、DNS相关命令

root@ubuntu:~# dig +trace www.baidu.com

DNS 的正、反解查询指令: host, nslookup, dig

root@ubuntu:~# host www.baidu.com 
www.baidu.com is an alias for www.a.shifen.com. 
www.a.shifen.com has address 119.75.218.77 
www.a.shifen.com has address 119.75.217.56 
Host www.a.shifen.com not found: 3(NXDOMAIN)

root@ubuntu:~# nslookup www.baidu.com 
Server:        192.168.77.2 
Address:    192.168.77.2#53

Non-authoritative answer: 
www.baidu.com    canonical name = www.a.shifen.com. 
Name:    www.a.shifen.com 
Address: 119.75.218.77 
Name:    www.a.shifen.com 
Address: 119.75.217.56

配置实例

1. 配置环境: 

DNS Server的ip:192.168.0.1  Client的ip范围为:192.168.0.2——192.168.0.254

要求DNS能解析 :
kxsrv.304.com 192.168.0.1

www.304.com 192.168.0.1

bbs.304.com    192.168.0.30

mail.304.com   192.168.0.20

网络拓扑如下:

2.安装软件bind。

检查是否安装bind.

#dpkg -l bind*

安装 BIND9

#sudo apt-get install bind9

3.DNS 配置文件介绍。

在/etc/bind 目录中。安装bind9后会生成如下三个配置文件: 
named.conf;named.conf.options;named.conf.local

其中 named.conf是主配置文件,里面包含了named.conf.options和named.conf.local,我们在架设本地dns时,只需改动named.conf.local即可。

4.配置分析。

根据上面的主机名称和ip对应可以看出: 
①需要添加正向区域“304.com”和反向区域“0.168.192.in-addr.arpa”, 
②在“304.com”区域中添加A记录kxsrv对应192.168.0.1, CNAME记录www对应kxsrv 
③在“0.168.192.in-addr.arpa”区域中添加各个ip地址对应的主机名

5.编辑named.conf.local。
先要添加写权限:#sudo chmod 646 named.conf.local 
添加下列语句: 
//正向区域 
zone "304.com" { 
type master; 
file "/etc/bind/db.304.com"; 
}; 
//反向区域 
zone "0.168.192.in-addr.arpa" { 
type master; 
notify no; 
file "/etc/bind/db.30.140.192"; 
}; 
然后保存。

6.建立named.conf.local中指定的区域文件。
在/etc/bind下建立正向区域文件 (复制了一份) 
命令:sudo cp /etc/bind/db.local /etc/bind/db.304.com 
在/etc/bind下建立反向区域文件 (复制了一份) 
命令:sudo cp /etc/bind/db.127 /etc/bind/db.0.168.192

7.编辑正向区域文件 
命令:sudo nano /etc/bind/db.304.com 
将原文参照下文修改 

; BIND data file for local loopback interface 

$TTL 604800 
@ IN SOA ns.304.com. root.304.com. ( 
2 ; Serial 
604800 ; Refresh 
86400 ; Retry 
2419200 ; Expire 
604800 ) ; Negative Cache TTL 

@ IN NS ns.304.com. 
@ IN A 127.0.0.1 
@ IN AAAA ::1 
ns IN A 192.168.0.1

kxsrv IN A 192.168.0.1

mail   IN A 192.168.0.20

bbs    IN A 192.168.0.30

www IN CNAME kxsrv

ns--------nameserver

A---------Address

CNAME----别名

注意修改的地方,在原文的localhost处更改,再添加各个主机记录 注意用Tab键分开对齐 
另外使用别名时:www IN cname 192.168.0.1 会出错, 要使用www IN cname kxsrv。

如果要添加ftp.304.com对应192.168.0.40,则只需在后面添加一行:

ftp    IN    A    192.168.0.40

8.编辑反向区域文件 
命令:sudo nano /etc/bind/db.0.168.192

将原文参照下文修改 

; BIND reverse data file for local loopback interface 

$TTL 604800 
@ IN SOA ns.304.com. root.304.com. ( 
1 ; Serial 
604800 ; Refresh 
86400 ; Retry 
2419200 ; Expire 
604800 ) ; Negative Cache TTL 

@ IN NS ns. 
9 IN PTR ns.304.com. 
9 IN PTR kxsrv.304.com. 
9 IN PTR www.304.com.

9 IN PTR bbs.304.com.

9 IN PTR mail.304.com.

注意修改的地方,在原文的localhost处更改,再添加各个主机记录 注意用Tab键分开对齐,末尾有“.”。

如果要添加ftp.304.com对应192.168.0.40,则只需在后面添加一行:

9 IN PTR ftp.304.com.

9.重新启动DNS服务 
sudo /etc/init.d/bind9 restart 
到此位置dns就配置完成了,你可以在XP下的cmd环境下用nslookup去试试看 
注意:改动配置文件后都要重新启动bind9。

10.Linux 修改DNS,请修改/etc/resolv.conf文件。 
例如: 
编辑sudo nano /etc/resolv.conf 
更改为 
nameserver 192.168.0.1

nameserver 202.117.112.3

将nameserver 192.168.0.1放在前面,这样主机会首先向nameserver 192.168.0.1请求解析。

11.DNS客户端的配置。
     此时DNS服务器已经开始工作了,要使用该DNS服务器,以XP为例,到"控制面板"–"网络连接",找到上网的网卡,右键选择"属性",改变DNS地址为192.168.0.1 ,否则会向其他DNS请求解析会导致不正确!

验证:在客户端

ping kxsrv.304.com

ping www.304.com

ping mail.304.com

总结:/etc/bind下文件之间的关系,

1、主要有三个配置文件:named.conf;named.conf.options;named.conf.local。(还有named.conf.default-zones等默认文件,不用管它)

2、其中named.conf是主配置文件,里面包含named.conf.options和named.conf.local,我们在架设本地dns时,只需改动named.conf.local即可。

3、先在named.conf.local中配置正向和反向区域,

正向区域的具体配置在/etc/bind/db.304.com文件中;(以本次试验为例)

正向区域的具体配置在/etc/bind/db.0.168.192文件中;(以本次试验为例)

然后到正向和反向的具体配置文件中配置。

再总结:只需改动在named.conf.local添加正向和反向区域;再到正向配置文件(在named.conf.local中指明了该文件的路径和名称)和反向配置文件(在named.conf.local中指明了该文件的路径和名称)中配置。

即以后要改域名直接替换上述三个文件的304字符串为要修改后的字符串即可。

要添加其他需要解析的域名(仍是304.com域,仍在192.168.0段内,非192.168.0.1地址),

如添加ftp.304.com对应地址192.168.0.20,只需在/etc/bind/db.304.com和/etc/bind/db.0.168.192中添加相应域名和地址即可.

参考:http://www.xkedu.cn/blog/read.php?478

linux的DNS相关介绍(转载)的更多相关文章

  1. 转载:Nginx 相关介绍

    转载自:https://www.cnblogs.com/wcwnina/p/8728391.html Nginx 相关介绍(Nginx是什么?能干嘛?)   Nginx的产生 没有听过Nginx?那么 ...

  2. [科普]DNS相关的攻击介绍

    一  什么是DNS DNS 是域名系统 (Domain Name System) 的缩写,是因特网的一项核心服务,它作为可以将域名和IP地址相互映射的一个分布式数据库,能够使人更方便的访问互联网,而不 ...

  3. linux 软连接创建 压缩解压缩 linux的dns服务相关

    linux软连接创建 注意用绝对路径,语法如下 ln -s 目标文件绝对路径 软连接名字绝对路径 ln -s /小护士.txt /tmp/hs.txt 修改linux的PS1变量,命令提示符变量 PS ...

  4. SONiC项目的发展及其相关介绍(转载)

    SONiC作为一个开源项目,理论上是包含了SAI(switch abstraction interface,交换机抽象接口),SAI是没有开源的,厂商自己完成统一的API,提供给上层sonic用户来调 ...

  5. Linux中与DNS相关的内容

    Linux中与DNS有关的三个东西: 1. 主机名 2. DNS服务器 3. Host文件 Linux中和DNS有关的三个文件: 1. /etc/hostname 2. /etc/resolv.con ...

  6. Linux中 /boot 目录介绍 【转载】

    Linux中 /boot 目录介绍 转自:点击打开链接 一./boot/目录中的文件和目录 Linux系统在本地启动时,目录/boot/非常重要,其中的文件和目录有: (1)系统Kernel的配置文件 ...

  7. linux用户权限相关内容查看

    linux用户权限相关内容查看 1   用户信息 创建用户一个名为 webuser 的账号,并填写相应的信息: root@iZ94fabhqhuZ:~# adduser webuser Adding ...

  8. Linux系统CPU相关信息查询

    Linux系统CPU相关信息查询 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.lscpu常用参数介绍 1>.查看帮助信息 [root@node105 ~]# lscpu ...

  9. 详细的linux目录结构详细介绍

    详细的linux目录结构详细介绍 --树状目录结构图 下面红色字体为比较重要的目录 1./目录 目录 描述 / 第一层次结构的根,整个文件系统层次结构的根目录 /bin/ 需要在单用户模式可用的必要命 ...

随机推荐

  1. Java面试题之线程与进程的区别

    进程是操作系统分配资源的最小单元: 线程是操作系统调度的最小单元: 一个程序至少有一个进程:一个进程至少有一个线程 每个进程对应一个JVM实例,多个线程共享JVM里的堆: 线程不能看做独立应用,而进程 ...

  2. springboot获取getBean方法以及ApplicationContext空指针问题解决

    创建获取ApplicationContext工具类: package com.performancetest.common.utils; import org.springframework.bean ...

  3. 【spring aop切面】基础使用教程

    package tpf.aspect; import org.apache.commons.logging.Log; import org.apache.commons.logging.LogFact ...

  4. bootstrap 事件shown.bs.modal用于监听并执行你自己的代码【写hostmanger关联部门遇到的问题及解决方法】

    背景:记录写hostmanger中用户下拉框关联部门遇到的问题及解决方法 问题:需求是展示页面展示用户所属的部门,点击修改按钮后,弹出对应的model,这个时候部门的select要默认选中用户所在的s ...

  5. linux 头文件以及库的路径

    原来在编译的时候可以指定执行时去哪里找需要的lib文件,长知识了 本文详细介绍了Linux 下gcc头文件指定方法,以及搜索路径顺序的问题.另外,还总结了,gcc动态链接的方法以及路径指定,同样也讨论 ...

  6. Linux内核解析:进程间通信:管道

    管道的定义管道的用途管道的操作管道非法read与write内核实现解析管道通信原理及其亲戚通信解析父子进程通信解析亲缘关系的进程管道通信解析管道的注意事项及其性质管道有以下三条性质shell管道的实现 ...

  7. Windows Builder(图形化界面的利器)For Eclipse 3.7

    工欲善其事,必先利其器——孔子(春秋)<论语·卫灵公> 今天闲逛论坛的时候,发现了Eclipse 的很好的插件,是关于做图形界面的. 如果想做桌面应用软件,交互界面有点复杂的时候,自己手动 ...

  8. BZOJ 4568 [Scoi2016]幸运数字(树链剖分 + 异或线性基)

    题目链接  BZOJ 4568 考虑树链剖分+线段树维护每一段区域的异或线性基 对于每个询问,求出该点集的异或线性基.然后求一下这个线性基里面能异或出的最大值即可. #include <bits ...

  9. linux grep 查找文件内容

    自试: wang@wang:~$ grep -i "*args*" ~/IGV01-SW/src/bzrobot_diagnostics/bzrobot_lightbelt_man ...

  10. CodeForces - 618F Double Knapsack

    Discription You are given two multisets A and B. Each multiset has exactly n integers each between 1 ...