如何使用 bind 設置 DNS 服務器

如何使用 bind 設置 DNS 服務器

本指南將向你展示如何配置一個主 DNS 系統以及客戶端。-- Curt Warfield(作者)

域名系統(Domain Name System),我們更通常稱為 DNS 的系統,可以將域名翻譯或轉換為與該域關聯的 IP 地址。DNS 是能夠讓你通過名稱找到自己喜歡的網站而不是在瀏覽器中輸入 IP 地址的原因。本指南將向你展示如何配置一個主 DNS 系統以及客戶端。

以下是本文示例中使用的系統細節:

<code>dns01.fedora.local    (192.168.1.160)- 主 DNS 服務器
client.fedora.local     (192.168.1.136)- 客戶端/<code>

DNS 服務器配置

使用 sudo 安裝 bind 包:

<code>$ sudo dnf install bind bind-utils -y/<code>

bind 包提供了 /etc/named.conf 配置文件,來供你配置 DNS 服務器。

編輯 /etc/named.conf 文件:

<code>sudo vi /etc/named.conf/<code>

查找以下行:

<code>listen-on port 53 { 127.0.0.1; };/<code>

添加主 DNS 服務器的 IP 地址,如下所示:

<code>listen-on port 53 { 127.0.0.1; 192.168.1.160; };/<code> 

查找以下行:

<code>allow-query  { localhost; };/<code>

添加本地網絡範圍。該示例系統使用的 IP 地址在 192.168.1.X 的範圍內。指定如下:

<code>allow-query  { localhost; 192.168.1.0/24; };/<code>

指定轉發和反向區域。 區域文件(Zone file)就是具有系統上 DNS 信息(例如 IP 地址和主機名)的文本文件。 轉發區域文件(forward zone file)使得將主機名轉換為 IP 地址成為可能。 反向區域文件(reverse zone file)則相反。它允許遠程系統將 IP 地址轉換為主機名。

在 /etc/named.conf 文件的底部查找以下行:

<code>include "/etc/named.rfc1912.zones";/<code>

在此處,你將在該行的正上方指定區域文件信息,如下所示:

<code>zone "dns01.fedora.local" IN {
  type master;
  file "forward.fedora.local";
  allow-update { none; };
};

zone "1.168.192.in-addr.arpa" IN {
  type master;
  file "reverse.fedora.local";
  allow-update { none; };
};/<code>

forward.fedora.local 和 reverse.fedora.local 文件是要創建的區域文件的名稱。它們可以是任意名字。

保存並退出。

創建區域文件

創建你在 /etc/named.conf 文件中指定的轉發和反向區域文件:

<code>$ sudo vi /var/named/forward.fedora.local/<code>

添加以下行:

<code>$TTL 86400
@   IN  SOA     dns01.fedora.local. root.fedora.local. (
        2011071001  ;Serial
        3600        ;Refresh
        1800        ;Retry
        604800      ;Expire
        86400       ;Minimum TTL
)
@       IN  NS          dns01.fedora.local.
@       IN  A           192.168.1.160
dns01           IN  A   192.168.1.160
client          IN  A   192.168.1.136/<code>

所有粗體(LCTT 譯註:本譯文中無法呈現粗體)內容都特定於你的環境。保存文件並退出。接下來,編輯 reverse.fedora.local 文件:

<code>$ sudo vi /var/named/reverse.fedora.local/<code>

添加以下行:

<code>$TTL 86400
@   IN  SOA     dns01.fedora.local. root.fedora.local. (
        2011071001  ;Serial
        3600        ;Refresh
        1800        ;Retry
        604800      ;Expire
        86400       ;Minimum TTL

)
@       IN  NS          dns01.fedora.local.
@       IN  PTR         fedora.local.
dns01           IN  A   192.168.1.160
client          IN  A   192.168.1.136
160     IN  PTR         dns01.fedora.local.
136     IN  PTR         client.fedora.local./<code>

所有粗體(LCTT 譯註:本譯文中無法呈現粗體)內容都特定於你的環境。保存文件並退出。

你還需要配置 SELinux 併為配置文件添加正確的所有權。

<code>sudo chgrp named -R /var/named
sudo chown -v root:named /etc/named.conf
sudo restorecon -rv /var/named
sudo restorecon /etc/named.conf/<code>

配置防火牆:

<code>sudo firewall-cmd --add-service=dns --perm
sudo firewall-cmd --reload/<code>

檢查配置是否存在語法錯誤

<code>sudo named-checkconf /etc/named.conf/<code>

如果沒有輸出或返回錯誤,那麼你的配置有效。

檢查轉發和反向區域文件。

<code>$ sudo named-checkzone forward.fedora.local /var/named/forward.fedora.local

$ sudo named-checkzone reverse.fedora.local /var/named/reverse.fedora.local/<code>

你應該看到 “OK” 的響應:

<code>zone forward.fedora.local/IN: loaded serial 2011071001
OK

zone reverse.fedora.local/IN: loaded serial 2011071001
OK/<code>

啟用並啟動 DNS 服務

<code>$ sudo systemctl enable named
$ sudo systemctl start named/<code>

配置 resolv.conf 文件

編輯 /etc/resolv.conf 文件:

<code>$ sudo vi /etc/resolv.conf/<code>

查找你當前的 nameserver 行。在示例系統上,使用調制解調器/路由器充當名稱服務器,因此當前看起來像這樣:

<code>nameserver 192.168.1.1/<code>

這需要更改為主 DNS 服務器的 IP 地址:

<code>nameserver 192.168.1.160/<code>

保存更改並退出。

不幸的是需要注意一點。如果系統重啟或網絡重啟,那麼 NetworkManager 會覆蓋 /etc/resolv.conf 文件。這意味著你將丟失所做的所有更改。

為了防止這種情況發生,請將 /etc/resolv.conf 設為不可變:

<code>$ sudo chattr +i /etc/resolv.conf/<code>

如果要重新設置,就需要允許其再次被覆蓋:

<code>$ sudo chattr -i /etc/resolv.conf/<code>

測試 DNS 服務器

<code>$ dig fedoramagazine.org/<code>
<code>; <<>> DiG 9.11.13-RedHat-9.11.13-2.fc30 <<>> fedoramagazine.org
;; global options: +cmd
;; Got answer:
;; ->>HEADER<;; flags: qr rd ra; QUERY: 1, ANSWER: 1, AUTHORITY: 3, ADDITIONAL: 6

;; OPT PSEUDOSECTION:
; EDNS: version: 0, flags:; udp: 4096
; COOKIE: c7350d07f8efaa1286c670ab5e13482d600f82274871195a (good)
;; QUESTION SECTION:
;fedoramagazine.org.        IN  A

;; ANSWER SECTION:
fedoramagazine.org.    50  IN  A   35.197.52.145

;; AUTHORITY SECTION:
fedoramagazine.org.    86150   IN  NS  ns05.fedoraproject.org.
fedoramagazine.org.    86150   IN  NS  ns02.fedoraproject.org.
fedoramagazine.org.    86150   IN  NS  ns04.fedoraproject.org.

;; ADDITIONAL SECTION:
ns02.fedoraproject.org.    86150   IN  A   152.19.134.139
ns04.fedoraproject.org.    86150   IN  A   209.132.181.17
ns05.fedoraproject.org.    86150   IN  A   85.236.55.10
ns02.fedoraproject.org.    86150   IN  AAAA    2610:28:3090:3001:dead:beef:cafe:fed5
ns05.fedoraproject.org.    86150   IN  AAAA    2001:4178:2:1269:dead:beef:cafe:fed5

;; Query time: 830 msec
;; SERVER: 192.168.1.160#53(192.168.1.160)
;; WHEN: Mon Jan 06 08:46:05 CST 2020
;; MSG SIZE  rcvd: 266/<code>

需要檢查幾件事以驗證 DNS 服務器是否正常運行。顯然,取得結果很重要,但這本身並不意味著 DNS 服務器實際上正常工作。

頂部的 QUERY、ANSWER 和 AUTHORITY 字段應顯示為非零,如我們的示例所示:

<code>;; flags: qr rd ra; QUERY: 1, ANSWER: 1, AUTHORITY: 3, ADDITIONAL: 6/<code>

並且 SERVER 字段應有你的 DNS 服務器的 IP 地址:

<code>;; SERVER: 192.168.1.160#53(192.168.1.160)/<code>

如果這是你第一次運行 dig 命令,請注意完成查詢要花費 830 毫秒的時間:

<code>;; Query time: 830 msec/<code>

如果再次運行它,查詢將會更快:

<code>$ dig fedoramagazine.org/<code>
<code>;; Query time: 0 msec
;; SERVER: 192.168.1.160#53(192.168.1.160)/<code>

客戶端配置

客戶端配置將簡單得多。

安裝 bind 程序:

<code>$ sudo dnf install bind-utils -y/<code>

編輯 /etc/resolv.conf 文件,並將主 DNS 配置為唯一的名稱服務器:

<code>$ sudo vi /etc/resolv.conf/<code>

它看起來像這樣:

<code>nameserver 192.168.1.160/<code>

保存更改並退出。然後,使 /etc/resolv.conf 文件不可變,防止其被覆蓋並變回默認設置:

<code>$ sudo chattr +i /etc/resolv.conf/<code>

測試客戶端

你應該獲得與 DNS 服務器相同的結果:

<code>$ dig fedoramagazine.org/<code>
<code>; <<>> DiG 9.11.13-RedHat-9.11.13-2.fc30 <<>> fedoramagazine.org
;; global options: +cmd
;; Got answer:
;; ->>HEADER<;; flags: qr rd ra; QUERY: 1, ANSWER: 1, AUTHORITY: 3, ADDITIONAL: 6

;; OPT PSEUDOSECTION:
; EDNS: version: 0, flags:; udp: 4096
; COOKIE: c7350d07f8efaa1286c670ab5e13482d600f82274871195a (good)
;; QUESTION SECTION:
;fedoramagazine.org.        IN  A

;; ANSWER SECTION:
fedoramagazine.org.    50  IN  A   35.197.52.145

;; AUTHORITY SECTION:
fedoramagazine.org.    86150   IN  NS  ns05.fedoraproject.org.
fedoramagazine.org.    86150   IN  NS  ns02.fedoraproject.org.
fedoramagazine.org.    86150   IN  NS  ns04.fedoraproject.org.

;; ADDITIONAL SECTION:
ns02.fedoraproject.org.    86150   IN  A   152.19.134.139
ns04.fedoraproject.org.    86150   IN  A   209.132.181.17
ns05.fedoraproject.org.    86150   IN  A   85.236.55.10
ns02.fedoraproject.org.    86150   IN  AAAA    2610:28:3090:3001:dead:beef:cafe:fed5
ns05.fedoraproject.org.    86150   IN  AAAA    2001:4178:2:1269:dead:beef:cafe:fed5

;; Query time: 1 msec
;; SERVER: 192.168.1.160#53(192.168.1.160)
;; WHEN: Mon Jan 06 08:46:05 CST 2020
;; MSG SIZE  rcvd: 266/<code>

確保 SERVER 輸出的是你 DNS 服務器的 IP 地址。

你的 DNS 服務器設置完成了,現在所有來自客戶端的請求都會經過你的 DNS 服務器了!


via: https://fedoramagazine.org/how-to-setup-a-dns-server-with-bind/

作者: Curt Warfield 選題: lujun9972 譯者: geekpi 校對: wxy

本文由 LCTT 原創編譯, Linux中國 榮譽推出


分享到:


相關文章: