配置DNS服务

DNS:Domain Name System:域名系统

DNS:Domain Name System:域名系统

域名和IP地址相互映射的一个分布式数据库,使用户使用域名更方便的访问互联网,不用去记更利于机器读取的IP地址,域名解析由DNS服务器提供。

DNS服务器的类型:

  • 主DNS服务器:管理和维护所负责解析的域内解析库的服务器

  • 从DNS服务器:从主服务器或从服务器“复制”(区域传输)解析库副本

  • 缓存DNS服务器(转发器)

一次完整的查询请求经过的流程:
 Client –>hosts文件–>DNS Service  Local Cache –> DNS Server (recursion) –>  
 Server Cache –> iteration(迭代) –> 根–> 顶级域名DNS–>二级域名DNS…

搭建域名解析服务器:
1.安装bind

相关软件包:bind、bind-chroot
]# yum install bind bind-chroot

  • BIND的服务名是 named,DNS默认协议是TCP与UDP协议,启动后会占用53/udp/tcp,953/tcp这两个端口号

    953是rndc的端口,rndc是控制Bind启动、关闭等行为的工具
     rndc status|reload

  • 若安装了bind-chroot,此时BIND的主配置文件会被封装到一个伪根目录内(安全目的),此时配置文件(链接)位置为:
    /var/named/chroot/etc/named.conf   BIND服务主配置文件
    /var/named/chroot/var/named/*.zone    域的zone配置文件

  • 默认配置文件:
    主配置文件:/etc/named.conf
    区域配置文件:/var/named/*.zone


2.配置DNS服务器:

主配置文件:/etc/named.conf

1.options {
2.    listen-on port 53 { 1localhost; };    监听的端口及地址;localhost表监听本机所有地址
3.    directory   "/var/named";        域文件的存放位置
4.    dump-file   "/var/named/data/cache_dump.db";
5.    statistics-file "/var/named/data/named_stats.txt";
6.    memstatistics-file "/var/named/data/named_mem_stats.txt";
7.    allow-query     { any; };    特定主机可发起查询,any表所有可查
8.    allow-transfer { none; };    设置允许指定主机抓取所有记录
9.    recursion yes;
10.
11.//  dnssec-enable yes;         安全相关可注释
12.//  dnssec-validation yes;       安全相关可注释
13.
14./* Path to ISC DLV key */
15.    bindkeys-file "/etc/named.iscdlv.key";
16.    managed-keys-directory "/var/named/dynamic";
17.};
18.
19.// 根服务器定义
20.zone "." IN {
21.    type hint;
22.    file "named.ca";
23.};
24.// 包含配置文件
25.include "/etc/named.rfc1912.zones";    可在该文件中定义域
26.include "/etc/named.root.key";

配置一个域名的解析:

  1. 在配置文件中添加域定义  /etc/named.conf 或 /etc/named.rfc1912.zones中

  2. 添加该域的zone文件至/var/named/xx.zone

主配置文件添加域定义:
]# vi /etc/named.rfc1912.zones添加:

1.//正向解析域定义
2.zone "rick.com" IN {
3.    type master;     类型 master|slave|hint|forward
4.    file "rick.zone";    必须与/var/named/ 目录下区域解析文件名相同
5.};
6.   //反向解析域定义,反写的网段地址.in-addr.arpa
7.zone "1.10.in-addr.arpa" IN {
8.    type master;    
9.    file "10.1.zone";
10.};

创建正向区域配置文件:

区域数据库文件各指令解释:

$TTL:允许客户端缓存来自查询的数据的默认时间,单位秒
 $ORIGIN:自动补全

资源记录类型:

A,AAAA,PTR,SOA,NS,CNAME,MX  
 SOA:Start Of Authority,起始授权记录;一个区域有且只能有一个SOA记录,须为第一条
 NS:Name Service,域名服务器记录;一个区域解析库可以有多个NS记录,其中一个为主
 A:Address,地址记录,FQDN > IPv4
 AAAA:FQDN > IPv6
 CNAME:Canonical Name,别名记录
 PTR:Pointer,IP > FQDN 反向解析
 MX:Mail eXchanger,邮件交换器;邮件记录必须有优先级:0-99,小优先级高

]# vi /var/named/rick.zone

1.$TTL 86400
2.$ORIGIN rick.com.
3.    IN     SOA    ns1.zz.com    root.zz.com. (
4.        16102204;序列号,可自定义;主服务器解析库变化时序列递增
5.        2H;与主服务器同步时间间隔
6.        20M;同步失败重试时长
7.        1W;无法联系主服务器时,多久后停止服务
8.        1D )否定答案TTL
9.            IN  NS    ns1.zz.com.  
10.ns1.zz.com. IN  A     10.1.235.6
11.www         IN  A     10.1.235.54

1.TTL可以从全局继承
 2.@可表示当前区域的名称
 3.相邻两条记录name相同时,后面可省略
 4.同一个名字可以有多条记录定义多个不同的值;DNS服务器会以轮询方式响应
 5.区域文件属性应修改为
         -rw-r—– 1  root named 149 Sep 22 16:02 NAME.zone

反向解析:
]# vi /var/named/10.1.zone   主要为PTR记录

1.$TTL 86400
2.$ORIGIN 1.10.in-addr.arpa.
3.@    IN    SOA   ns1.zz.com.   root.zz.com.  ( 16101602 2H 10M 1W 1D )
4.         IN      NS     ns1.zz.com.
5.6.235    IN      PTR    ns1.zz.com.
6.54.235   IN      PTR    www.rick.com.

主配置文件语法检查:
]# named-checkconf
解析库文件语法检查:
]# named-checkzone rick.com  /var/named/rick.com
]# named-checkzone 1.10.in-addr.arpa  /var/named/10.1.zone
启动服务:
service named start


对DNS配置完成后就可以测试了,linux下有下列几个测试工具:

  • dig

  • host

  • nslook

# dig [+trace] [-t A|AAAA..] name [@server]
   @server:指定主机解析
   +trace:跟踪解析过程
   -t:指定类型
   -x:反向解析 不一定存在

]# dig -t axfr .1.10.in-addr.arpa @10.1.252.54
]# dig -t ptr 33.252.1.10.in-addr.arpa @10.1.252.54

# host [-t RR_type] name [server_IP]

]# host -t NS zjj.com @127.0.0.0

# nslookup [-options] [name] [server]   lnx/win
       交互模式:
           nslookup
               >server IP  指明使用哪个DNS server进行查询
               >set q=RR_type  指明查询的资源记录类型
               >NAME  要查询的名称

管理:
# rndc named服务控制命令:start|stop|reload|status    状态|flush    清空缓存

原创文章,作者:Jasper,如若转载,请注明出处:http://www.178linux.com/52827

(0)
JasperJasper
上一篇 2016-10-24
下一篇 2016-10-24

相关推荐

  • 少走冤枉路!带你走过SNMP的那些坑

    SNMP(Simple Network Management Protocol)即简单网络管理协议,是在网络与系统监控领域中,最常使用的一种数据采集技术。尽管这个协议非常简单,但在大规模IT环境监测中,还是经常会碰到各种坑,因此优云开源了一套友好的SNMPAPI,并通过本文简单介绍这套API中的一些特点,希望帮助各位运维同仁提前规避一些问题。 特点[0].&…

    2016-06-22
  • 磁盘分区相关知识

    磁盘分区相关知识 使用磁盘分区的过程设备识别→设备分区→创建文件系统→标记文件系统→在/etc/fstab文件中创建条目→挂载新的文件系统 分区不是必须的,但是分区是必要的:优化I/O性能实现磁盘空间配额限制提高修复速度隔离系统和程序安装多个OS采用不同文件系统 不重启激活新添加的磁盘:echo “- – -” > …

    Linux干货 2017-08-20
  • LVS常见的类型实现方式

    前言  由于lvs的基础知识已经在第一篇lvs中讲解了,所以在这里只做实验,包括lvs-nat,lvs-dr,以及基于Freiwall标记和实现会话绑定实验。 一、lvs-nat:也是MASQERADING,简称为m(masquerading)    实验图:     地址规划:     …

    Linux干货 2015-06-29
  • Kickstart+PXE自动部署

    Kickstart+PXE自动部署 无人值守安装简介 无人值守安装(Unattended Setup)指软件安装时无需任何用户干预,直接按默认或通过应答文件设置安装,这对于无特殊需求的用户或企业大批量部署安装操作系统及软件时非常方便。无人值守安装也称为静默安装,在安装过程中可以静默安装好预先设计集成的一些常用软件,安装结束以后软件就已经可以使用,很多软件都支…

    Linux干货 2016-09-17
  • vim的简单应用

    vim的简单应用         之前我们学习过Linux的思想,其中有一条就是一切皆文本,所以在这里大部分配置文件都是文本模式存在的,那么使用简单的文字编辑器就可以修改配置了,之前我们学习过nano文本编辑器,但是Vim会比nano使用的更为方便,也更强大。 基本现在所有的Li…

    2017-06-17
  • Btrfs文件系统的管理和应用

        Btrfs(我们称之为Butter FS或者B-tree FS)被称为新一代的linux文件系统。一直以来,EXT文件系统以其卓越的稳定性成为linux标准的文件系统。但近年来,EXT3暴露出一些扩展性的问题(如单一文件大小限制、总文件系统大小限制等),于是便催生了EXT4。但同时,Btrfs向人们展现出诸多优…

    Linux干货 2016-02-14