Linux 《系统搭建及配置 DNS 服务器》实验报告

WechatIMG691.jpeg

DNS域名分级

# 格式
主机名.二级域名.顶级域名.
# 例如
www.yuhal.com

根域可以忽略不写,例如www.yuhal.com不用写成www.yuhal.com.

620b0af774c4b_620b0af774c46.png

DNS域名解析流程

620b0e1e55141_620b0e1e55139.jpeg

DNS解析优先级

  • /etc/nsswitch.conf

修改 DNS 查询的顺序

  • /etc/hosts

存放常用的 DNS 记录与开发中测试使用的服务器记录。

  • /etc/resolv.conf

设定 DNS 服务器。

DNS的安装

下面使用 BIND9 来搭建 DNS 服务器。

  • 更新源
$ apt-get update
  • 安装和配置 BIND
$ apt-get install -y bind9 bind9utils bind9-doc
  • 激活 IPv4 Mode
OPTIONS="-4 -u bind"

在 /etc/default/bind9 文件中,修改 OPTIONS 变量。

DNS服务器的配置

一般都会设置两个 DNS 服务器,一个主要的,一个备用的,这里只配置主 DNS 服务器。

  • 查看主配置文件 named.conf
// This is the primary configuration file for the BIND DNS server named.
//
// Please read /usr/share/doc/bind9/README.Debian.gz for information on the
// structure of BIND configuration files in Debian, *BEFORE* you customize
// this configuration file.
//
// If you are just adding zones, please do that in /etc/bind/named.conf.local

include "/etc/bind/named.conf.options";
include "/etc/bind/named.conf.local";
include "/etc/bind/named.conf.default-zones";

BIND 的配置由多个文件组成,这些文件包含在主配置文件中 named.conf。

  • 修改 /etc/bind/named.conf.options
acl "trusted" {
    10.0.2.14; # ns1 信任的名单
};
options {
    directory "/var/cache/bind";

    // If there is a firewall between you and nameservers you want
    // to talk to, you may need to fix the firewall to allow multiple
    // ports to talk.  See http://www.kb.cert.org/vuls/id/800113

    // If your ISP provided one or more IP addresses for stable
    // nameservers, you probably want to use them as forwarders.
    // Uncomment the following block, and insert the addresses replacing
    // the all-0's placeholder.

    recursion  yes;                     # enables resursive queries
    allow-recursion { trusted; };   # allows recursive queries from "trusted" clients
    listen-on { 10.0.2.14;  };   # ns1 private IP address - listen on private network only
    allow-transfer { none; };       # disable zone transfers by default

    forwarders {
        114.114.114.114;            # 当本地的 dns 服务器中找不到记录时向上查询
    };

    //========================================================================
    // If BIND logs error messages about the root key being expired,
    // you will need to update your keys.  See https://www.isc.org/bind-keys
    //========================================================================
    dnssec-validation auto;

    auth-nxdomain no;    # conform to RFC1035
    listen-on-v6 { any; };
};

10.0.2.14 是本机的 ip 地址,114.114.114.114 是非用于商业用途的 DNS 服务器。注意:粘贴前请先设置:set paste。有关各配置详细解释可参考 BIND 官方配置项文档

  • 修改 /etc/bind/named.conf.local
//
// Do any local configuration here
//

// Consider adding the 1918 zones here, if they are not used in your
// organization
//include "/etc/bind/zones.rfc1918";

zone "yuhal.example.com" {
    type master;
    file "/etc/bind/zones/db.yuhal.example.com"; # zone file path
};

zone "14.2.0.10.in-addr.arpa" {
    type master;
    file "/etc/bind/zones/db.10.0.2.14";
};

该文件中配置了正向解析反向解析的文件在系统中的位置,简单的说,正向解析就是根据域名查 ip,反向就是根据 ip 查域名。

  • 创建正反解析文件的目录
$ mkdir /etc/bind/zones
  • 创建正向解析域文件
$ cp /etc/bind/db.local /etc/bind/zones/db.yuhal.example.com
  • 修改 /etc/bind/zones/db.yuhal.example.com
;
; BIND data file for local loopback interface
$TTL    604800
@       IN      SOA     ns1.yuhal.example.com. admin.yuhal.example.com. (
                  3       ; Serial
             604800     ; Refresh
              86400     ; Retry
            2419200     ; Expire
             604800 )   ; Negative Cache TTL
;
;
; name servers - NS records
     IN      NS      ns1.yuhal.example.com.
; name servers - A records
ns1.yuhal.example.com.          IN      A       10.0.2.14

host1.yuhal.example.com.        IN      A      10.0.2.14
  • 创建反向解析域文件
$ cp /etc/bind/db.127 /etc/bind/zones/db.10.0.2.14
  • 修改 /etc/bind/zones/db.10.0.2.14
;
; BIND reverse data file for local loopback interface
;
$TTL    604800
@       IN      SOA     yuhal.example.com. admin.yuhal.example.com. (
                              3         ; Serial
                         604800         ; Refresh
                          86400         ; Retry
                        2419200         ; Expire
                         604800 )       ; Negative Cache TTL
; name servers
      IN      NS      ns1.yuhal.example.com.

; PTR Records
14.2   IN      PTR     ns1.yuhal.example.com.    ; 10.0.2.14
14.2   IN      PTR     host1.yuhal.example.com.  ; 10.0.2.14
  • 正反向解析域文件详解
记录类型 作用
A 记录 正向解析记录,域名到 IP 地址的映射
NS 记录 域名服务器记录(NS 为 NameServer)
MX 记录 邮件记录
PTR 记录 反向解析记录,IP 地址到域名的映射
CNAME 记录 别名记录,为主机添加别名
SOA 记录 域权威记录,说明本服务器为域管理服务器
AAAA 记录 正向解析记录,域名到 IPv6 地址的映射
  • 检验 BIND 配置文件语法是否错误
$ named-checkconf
  • 检验正向解析和反向解析文件是否正确
$ named-checkzone yuhal.example.com /etc/bind/zones/db.yuhal.example.com
zone yuhal.example.com/IN: loaded serial 3
OK
$ named-checkzone 0.10.in-addr.arpa /etc/bind/zones/db.10.0
zone 0.10.in-addr.arpa/IN: loaded serial 3
OK
  • 重启 BIND service
$ service bind9 restart

DNS客户端配置

options timeout:1 attempts:1 rotate
nameserver 10.0.2.14 # 本机的ip地址

修改 /etc/resolv.conf,内容如上。

验证

  • 运行 dns 服务器在前台
$ named -g
  • 再打开一个终端,查询服务器
$ nslookup host1.yuhal.example.com
Server:     10.0.2.14
Address:    10.0.2.14#53

Name:   host1.yuhal.example.com
Address: 10.0.2.14

$ nslookup 10.0.2.14
Server:     10.0.2.14
Address:    10.0.2.14#53

14.2.0.10.in-addr.arpa      name = host1.yuhal.example.com.
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 199,636评论 5 468
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 83,890评论 2 376
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 146,680评论 0 330
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 53,766评论 1 271
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 62,665评论 5 359
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,045评论 1 276
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,515评论 3 390
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,182评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,334评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,274评论 2 317
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,319评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,002评论 3 315
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,599评论 3 303
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,675评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,917评论 1 255
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,309评论 2 345
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 41,885评论 2 341

推荐阅读更多精彩内容