溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

使用 bind 設(shè)置 DNS 服務(wù)器的方法

發(fā)布時(shí)間:2020-09-20 13:10:21 來源:腳本之家 閱讀:239 作者:Curt Warfield 欄目:服務(wù)器

DNS(Domain Name Server,域名服務(wù)器)是進(jìn)行域名(domain name)和與之相對應(yīng)的IP地址 (IP address)轉(zhuǎn)換的服務(wù)器。

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

以下是本文示例中使用的系統(tǒng)細(xì)節(jié):

dns01.fedora.local (192.168.1.160)- 主 DNS 服務(wù)器
client.fedora.local (192.168.1.136)- 客戶端

DNS 服務(wù)器配置

使用 sudo 安裝 bind 包:

$ sudo dnf install bind bind-utils -y

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

編輯 /etc/named.conf 文件:

sudo vi /etc/named.conf

查找以下行:

listen-on port 53 { 127.0.0.1; };

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

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

查找以下行:

allow-query { localhost; };

添加本地網(wǎng)絡(luò)范圍。該示例系統(tǒng)使用的 IP 地址在 192.168.1.X 的范圍內(nèi)。指定如下:

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

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

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

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

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

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 文件是要?jiǎng)?chuàng)建的區(qū)域文件的名稱。它們可以是任意名字。

保存并退出。

創(chuàng)建區(qū)域文件

創(chuàng)建你在 /etc/named.conf 文件中指定的轉(zhuǎn)發(fā)和反向區(qū)域文件:

$ 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 譯注:本譯文中無法呈現(xiàn)粗體)內(nèi)容都特定于你的環(huán)境。保存文件并退出。接下來,編輯 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 譯注:本譯文中無法呈現(xiàn)粗體)內(nèi)容都特定于你的環(huán)境。保存文件并退出。

你還需要配置 SELinux 并為配置文件添加正確的所有權(quán)。

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

檢查配置是否存在語法錯(cuò)誤

sudo named-checkconf /etc/named.conf

如果沒有輸出或返回錯(cuò)誤,那么你的配置有效。

檢查轉(zhuǎn)發(fā)和反向區(qū)域文件。

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

你應(yīng)該看到 “OK” 的響應(yīng):

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

啟用并啟動(dòng) DNS 服務(wù)

$ sudo systemctl enable named
$ sudo systemctl start named

配置 resolv.conf 文件

編輯 /etc/resolv.conf 文件:

$ sudo vi /etc/resolv.conf

查找你當(dāng)前的 nameserver 行。在示例系統(tǒng)上,使用調(diào)制解調(diào)器/路由器充當(dāng)名稱服務(wù)器,因此當(dāng)前看起來像這樣:

nameserver 192.168.1.1

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

nameserver 192.168.1.160

保存更改并退出。

不幸的是需要注意一點(diǎn)。如果系統(tǒng)重啟或網(wǎng)絡(luò)重啟,那么 NetworkManager 會(huì)覆蓋 /etc/resolv.conf 文件。這意味著你將丟失所做的所有更改。

為了防止這種情況發(fā)生,請將 /etc/resolv.conf 設(shè)為不可變:

$ sudo chattr +i /etc/resolv.conf

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

$ sudo chattr -i /etc/resolv.conf

測試 DNS 服務(wù)器

$ 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

需要檢查幾件事以驗(yàn)證 DNS 服務(wù)器是否正常運(yùn)行。顯然,取得結(jié)果很重要,但這本身并不意味著 DNS 服務(wù)器實(shí)際上正常工作。

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

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

并且 SERVER 字段應(yīng)有你的 DNS 服務(wù)器的 IP 地址:

;; SERVER: 192.168.1.160#53(192.168.1.160)

如果這是你第一次運(yùn)行 dig 命令,請注意完成查詢要花費(fèi) 830 毫秒的時(shí)間:

;; Query time: 830 msec

如果再次運(yùn)行它,查詢將會(huì)更快:

$ 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 配置為唯一的名稱服務(wù)器:

$ sudo vi /etc/resolv.conf

它看起來像這樣:

nameserver 192.168.1.160

保存更改并退出。然后,使 /etc/resolv.conf 文件不可變,防止其被覆蓋并變回默認(rèn)設(shè)置:

$ sudo chattr +i /etc/resolv.conf

測試客戶端

你應(yīng)該獲得與 DNS 服務(wù)器相同的結(jié)果:

$ 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 服務(wù)器的 IP 地址。

你的 DNS 服務(wù)器設(shè)置完成了,現(xiàn)在所有來自客戶端的請求都會(huì)經(jīng)過你的 DNS 服務(wù)器了!

為什么要搭建一個(gè)簡單的DNS服務(wù)器?

(1)當(dāng)外網(wǎng)DNS崩潰,比如暴風(fēng)門發(fā)生的那種情況,可以使用我們自己的DNS應(yīng)急

(2)為內(nèi)網(wǎng)網(wǎng)站提供內(nèi)線的IP地址解析,或者實(shí)現(xiàn)雙線解析

(3)當(dāng)你的ISP限制了二級域名和高級管理特性,你需要自己搭建DNS服務(wù)器來滿足自己的需要

(4)避免DNS劫持

(5)和別的解決方案集成

總結(jié)

到此這篇關(guān)于使用 bind 設(shè)置 DNS 服務(wù)器的文章就介紹到這了,更多相關(guān)bind dns服務(wù)器內(nèi)容請搜索億速云以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持億速云!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI