原文地址: http://blog.chinaunix.net/uid-29622064-id-4242123.html

1.DNS服务器简介

域名系统英文Domain Name System,縮寫DNS)是因特网的一项服务。它作为将域名IP地址相互映射的一个分布式数据库,能够使人更方便的访问互联网。DNS 使用TCPUDP端口53。当前,对于每一级域名长度的限制是63个字符,域名总长度则不能超过253个字符。

在dns出现之前,我们把域名和IP的对照存放在/etc/hosts文件里边,但是随着IP的不断增大,使用文件存放显得不够了。而且不利于和其他的主机进行同步,DNS应运而生。

DNS的结构:他是利用树形目录的架构。将主机名的管理分配在不同层级的DNS服务器,让每一层的修改和查找都变得功能单一。

DNS查询主机名的流程:

(1)先在本机有没有记录,没有的话向(.root)查询;
(2)向最顶层的.查询;
(3)然后分层的查询,每次只查询它所对的下一层。
(4)查到之后记录缓存,并且将路径返回给用户。

注:在系统中我们可以通过dig命令进行路径追踪。

工作流程如图所示:

2.搭建DNS服务器

今天我们来自己搭建一个DNS服务器,这样的需求在公司的内部还是有的。

首先我们来查找安装dns的包有那些:

安装dns服务器:

开启服务后看到dns服务开启的端口号是53:

接下来我们要修改配置文件提供相应的服务,这里我们为了安全期间,在/var/named/chroot的目录下修改配置文件,而不直接对/etc/named目录下的文件进行修改,两者是同步的,但是有一个约束条件,前者只有在dns开启成功的情况下才能使用!!!

我们在选项中关闭了ipv6的开放,而且允许任意用户使用。

主配置文件的最后两行分别是副配置文件和我们的dns加密文件:

(1)DNS的正向解析:
我们依次来查看:

我们来设置自己的域名系统,上边的是模板,底下的我们指定了域名配置文件的名称,这个要自己创建,位置在/var/named/chroot/var/named下:

这个目录底下也有域名配置文件的模板,我们拷贝一份并进行设置:

这个是初始模样,请务必记住,并且和修改之后的进行对比:

修改之后的:

注意:这里的@等于example.com. 所以在最后两行,如果没有把域名补全的话,系统会把@所代表的值添加到末尾,并且注意每个com后边还有一个点。

这个时候我们重启服务,并且查看火墙是否已经关闭:

服务端设置好之后,我们在另外一台机子上访问dns服务器。

首先要做的就是修改ifcfg-eth0文件里的DNS1参数为指定DNS服务器的IP:192.168.2.100.然后重新启动network服务:


重新启动network:

我们追踪了一下,发现可以找到www.example.com,并且dns服务器为192.168.2.100这就说明我么之前的dns服务器配置是没有问题的。

上述部分是dns服务器的正向解析,同时我们还知道dns具有反向解析的能力,那如何实现呢,当然还是要修改配置文件了,与正向解析的步骤差别不大。

(2)DNS的反向解析:

回到副配置文件中,在目录/var/named/chroot/etc下:

看到我们IP的书写格式了么,是的,既然是反向解析,IP的书写顺序也是相反的,并且指定了配置文件:

跳转到配置文件目录,首先我们拷贝反向解析配置文件的模板,然后进行编辑:

这个是模板的格式:

我们修改之后的样子:

记住最后一行,它代表的意思是192.168.2.200所对应的域名是ptr.example.com.这个是我们等会检验配置是否正确的标准。

退出保存后重启dns服务:

回到客户机我们来反向解析一下192.168.2.200是什么域名:

小结:

如上所讲,dns的正向解析和反向解析已经完成,但是这样的功能有点单一化,事实上它还有些不使用,比如说如何去同步的修改,如何和dhcp共同协作提供ddns的服务,这些我们在下节讲解。

最新文章

  1. Jquery源码学习(第一天)
  2. [NOIP2011] 聪明的质检员(二分答案)
  3. RCA端子颜色(红、白、黄)
  4. 【leetcode❤python】141. Linked List Cycle
  5. android向web提交参数的4种方式总结,附带网站案例源码
  6. js判断小数点几位
  7. 【转】SQL常用的语句和函数
  8. poj 1679 The Unique MST(唯一的最小生成树)
  9. js技术要点---JS 获取网页源代码
  10. iOS 按钮设置图片和事件
  11. 微信小程序使用场景延伸:扫码登录、扫码支付
  12. NSAttributedString富文本简单介绍和常用方法浅析
  13. svg绘制一个简单地饼图
  14. configSections必须是根节点下第一个节点
  15. MySql事务的隔离级别及作用
  16. druid的关键参数+数据库连接池运行原理
  17. Matlab中导入文本文件中的数据 矩阵合并 以及C++中删除文件操作
  18. R: Coercing LHS to a list
  19. Linux及Windows系统配置JDK环境变量
  20. POJ-3744 Scout YYF I (矩阵优化概率DP)

热门文章

  1. I.MX6 默认打开 USB adb
  2. webapp调试工具weinre的使用
  3. uestc 1721 吴神,人类的希望
  4. 【转】Android 如何在Eclipse中查看Android API源码 及 support包源码
  5. JS三级折叠菜单特效 自动收缩其它级
  6. 零基础编程指南(By Turtle)
  7. 编译boost (windows msvc14)
  8. Redis常用命令手册:服务器相关命令
  9. C# Read/Write another Process' Memory z
  10. HDU-4882 ZCC Loves Codefires