如何使用 bind 設定 DNS 伺服器
域名系統,我們更通常稱為 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; };
指定轉發和反向區域。區域檔案就是具有系統上 DNS 資訊(例如 IP 地址和主機名)的文字檔案。轉發區域檔案使得將主機名轉換為 IP 地址成為可能。反向區域檔案則相反。它允許遠端系統將 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.local
和 reverse.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.160
dns01 IN A 192.168.1.160
client 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.160
client IN A 192.168.1.136
160 IN PTR dns01.fedora.local.
136 IN PTR client.fedora.local.
所有粗體(LCTT 譯註:本譯文中無法呈現粗體)內容都特定於你的環境。儲存檔案並退出。
你還需要配置 SELinux 併為配置檔案新增正確的所有權。
sudo chgrp named -R /var/named
sudo chown -v root:named /etc/named.conf
sudo restorecon -rv /var/named
sudo restorecon /etc/named.conf
配置防火牆:
sudo firewall-cmd --add-service=dns --perm
sudo 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 2011071001
OK
zone reverse.fedora.local/IN: loaded serial 2011071001
OK
啟用並啟動 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 伺服器實際上正常工作。
頂部的 QUERY
、ANSWER
和 AUTHORITY
欄位應顯示為非零,如我們的示例所示:
;; 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 伺服器了!
via: https://fedoramagazine.org/how-to-setup-a-dns-server-with-bind/
作者:Curt Warfield 選題:lujun9972 譯者:geekpi 校對:wxy
訂閱“Linux 中國”官方小程式來檢視
相關文章
- DNS軟體bind-實現DNS伺服器DNS伺服器
- DNS和BINDDNS
- DNS之BIND使用小結(Forward轉發)DNSForward
- win10 最優dns如何設定_win10設定最優dns步驟Win10DNS
- 伺服器:Ubuntu設定IP地址、閘道器、DNS伺服器UbuntuDNS
- DNS Bind日誌詳述DNS
- 伺服器dns怎麼設定 伺服器遠端登入教程伺服器DNS
- dns設定哪個最好最快 最快最穩定的dnsDNS
- 手動設定ip地址和dns ip地址和dns怎麼設定DNS
- DNS解析服務(bind)安裝DNS
- debian 12設定靜態ip、dnsDNS
- 192.168.1.1的首選dns 手動設定IP地址和DNSDNS
- 如何修改域名DNS伺服器?修改DNS伺服器常見問題彙總DNS伺服器
- 中科三方:DNS解析如何設定合適的TTL值?DNS
- win10 dns設定在哪裡_window10最快dns怎麼設定Win10DNS
- DNS伺服器設定有什麼作用?——VecloudDNS伺服器Cloud
- linux伺服器—配置bindLinux伺服器
- Linux伺服器---配置bindLinux伺服器
- 使用Dnsmasq搭建本地dns伺服器上網DNS伺服器
- 如何解決DNS伺服器未響應DNS伺服器
- dns伺服器DNS伺服器
- [譯] 如何在 JavaScript 中使用 apply(?),call(?),bind(➰)JavaScriptAPP
- 雲伺服器:如何設定springboot啟動埠伺服器Spring Boot
- 伺服器如何設定多個不同ip地址伺服器
- Win10系統下電腦設定DNS地址的方法 電腦的DNS怎麼設定才能上網?Win10DNS
- Linux伺服器—安裝bindLinux伺服器
- Linux伺服器---安裝bindLinux伺服器
- Windows10系統如何設定NFS伺服器_win10設定NFS伺服器圖文教程WindowsNFS伺服器Win10
- 伺服器如何設定Windows Server 2012防火牆管理伺服器WindowsServer防火牆
- 伺服器window如何設定防火牆開放埠伺服器防火牆
- DNS域名伺服器DNS伺服器
- DNS/DHCP 伺服器DNS伺服器
- Ubuntu系統設定IP地址、閘道器、DNSUbuntuDNS
- JS每日一題: Call,Apply,Bind的使用與區別,如何實現一個bind?JS每日一題APP
- DNS解析常見問題:什麼是主DNS伺服器和輔助DNS伺服器?DNS伺服器
- DNS入門學習:什麼是TTL值?如何設定合適的TTL值?DNS
- 使用queryperf對DNS伺服器作壓力測試DNS伺服器
- 雲伺服器如何解決DNS解析錯誤故障伺服器DNS