如何使用 bind 設定 DNS 伺服器

2020-03-15 10:44:00

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

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

dns01.fedora.local    (192.168.1.160)- 主 DNS 伺服器client.fedora.local     (192.168.1.136)- 用戶端

DNS 伺服器設定

使用 sudo 安裝 bind 包:

$ sudo dnf install bind bind-utils -y

bind 包提供了 /etc/named.conf 組態檔,來供你設定 DNS 伺服器。

編輯 /etc/named.conf 檔案:

sudo vi /etc/named.conf

查詢以下行:

listen-on port 53 { 127.0.0.1; };

新增主 DNS 伺服器的 IP 地址,如下所示:

listen-on port 53 { 127.0.0.1; 192.168.1.160; };

查詢以下行:

allow-query  { localhost; };

新增本地網路範圍。該範例系統使用的 IP 地址在 192.168.1.X 的範圍內。指定如下:

allow-query  { localhost; 192.168.1.0/24; };

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

/etc/named.conf 檔案的底部查詢以下行:

include "/etc/named.rfc1912.zones";

在此處,你將在該行的正上方指定區域檔案資訊,如下所示:

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; };};

forward.fedora.localreverse.fedora.local 檔案是要建立的區域檔案的名稱。它們可以是任意名字。

儲存並退出。

建立區域檔案

建立你在 /etc/named.conf 檔案中指定的轉發和反向區域檔案:

$ sudo vi /var/named/forward.fedora.local

新增以下行:

$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.160dns01           IN  A   192.168.1.160client          IN  A   192.168.1.136

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

$ sudo vi /var/named/reverse.fedora.local

新增以下行:

$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.160client          IN  A   192.168.1.136160     IN  PTR         dns01.fedora.local.136     IN  PTR         client.fedora.local.

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

你還需要設定 SELinux 並為組態檔新增正確的所有權。

sudo chgrp named -R /var/namedsudo chown -v root:named /etc/named.confsudo restorecon -rv /var/namedsudo restorecon /etc/named.conf

設定防火牆:

sudo firewall-cmd --add-service=dns --permsudo firewall-cmd --reload

檢查設定是否存在語法錯誤

sudo named-checkconf /etc/named.conf

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

檢查轉發和反向區域檔案。

$ sudo named-checkzone forward.fedora.local /var/named/forward.fedora.local$ sudo named-checkzone reverse.fedora.local /var/named/reverse.fedora.local

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

zone forward.fedora.local/IN: loaded serial 2011071001OKzone reverse.fedora.local/IN: loaded serial 2011071001OK

啟用並啟動 DNS 服務

$ sudo systemctl enable named$ sudo systemctl start named

設定 resolv.conf 檔案

編輯 /etc/resolv.conf 檔案:

$ sudo vi /etc/resolv.conf

查詢你當前的 nameserver 行。在範例系統上,使用數據機/路由器充當名稱伺服器,因此當前看起來像這樣:

nameserver 192.168.1.1

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

nameserver 192.168.1.160

儲存更改並退出。

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

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

$ sudo chattr +i /etc/resolv.conf

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

$ sudo chattr -i /etc/resolv.conf

測試 DNS 伺服器

$ dig fedoramagazine.org
; <<>> DiG 9.11.13-RedHat-9.11.13-2.fc30 <<>> fedoramagazine.org;; global options: +cmd;; Got answer:;; ->>HEADER<<- opcode: QUERY, status: NOERROR, id: 8391;; 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

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

頂部的 QUERYANSWERAUTHORITY 欄位應顯示為非零,如我們的範例所示:

;; flags: qr rd ra; QUERY: 1, ANSWER: 1, AUTHORITY: 3, ADDITIONAL: 6

並且 SERVER 欄位應有你的 DNS 伺服器的 IP 地址:

;; SERVER: 192.168.1.160#53(192.168.1.160)

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

;; Query time: 830 msec

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

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

用戶端設定

用戶端設定將簡單得多。

安裝 bind 程式:

$ sudo dnf install bind-utils -y

編輯 /etc/resolv.conf 檔案,並將主 DNS 設定為唯一的名稱伺服器:

$ sudo vi /etc/resolv.conf

它看起來像這樣:

nameserver 192.168.1.160

儲存更改並退出。然後,使 /etc/resolv.conf 檔案不可變,防止其被覆蓋並變回預設設定:

$ sudo chattr +i /etc/resolv.conf

測試用戶端

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

$ dig fedoramagazine.org
; <<>> DiG 9.11.13-RedHat-9.11.13-2.fc30 <<>> fedoramagazine.org;; global options: +cmd;; Got answer:;; ->>HEADER<<- opcode: QUERY, status: NOERROR, id: 8391;; 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

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

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