您的位置:首頁 > 教程 > linux > 使用 bind 設置 DNS 服務器的方法

使用 bind 設置 DNS 服務器的方法

2022-06-19 07:33:31 來源:易采站長站 作者:

使用 bind 設置 DNS 服務器的方法

Bind9是一個強大的linux下開放源代碼的DNS服務器軟件,這篇文章主要介紹了使用 bind 設置 DNS 服務器的方法,需要的朋友可以參考下hIT站長之家-易采站長站-Easck.Com

DNS(Domain Name Server,域名服務器)是進行域名(domain name)和與之相對應的IP地址 (IP address)轉換的服務器。hIT站長之家-易采站長站-Easck.Com

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

以下是本文示例中使用的系統細節:hIT站長之家-易采站長站-Easck.Com

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

DNS 服務器配置hIT站長之家-易采站長站-Easck.Com

使用 sudo 安裝 bind 包:hIT站長之家-易采站長站-Easck.Com

$ sudo dnf install bind bind-utils -y

bind 包提供了 /etc/named.conf 配置文件,來供你配置 DNS 服務器。hIT站長之家-易采站長站-Easck.Com

編輯 /etc/named.conf 文件:hIT站長之家-易采站長站-Easck.Com

sudo vi /etc/named.conf

查找以下行:hIT站長之家-易采站長站-Easck.Com

listen-on port 53 { 127.0.0.1; };

添加主 DNS 服務器的 IP 地址,如下所示:hIT站長之家-易采站長站-Easck.Com

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

查找以下行:hIT站長之家-易采站長站-Easck.Com

allow-query { localhost; };

添加本地網絡范圍。該示例系統使用的 IP 地址在 192.168.1.X 的范圍內。指定如下:hIT站長之家-易采站長站-Easck.Com

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

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

/etc/named.conf 文件的底部查找以下行:hIT站長之家-易采站長站-Easck.Com

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

在此處,你將在該行的正上方指定區域文件信息,如下所示:hIT站長之家-易采站長站-Easck.Com

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 文件是要創建的區域文件的名稱。它們可以是任意名字。hIT站長之家-易采站長站-Easck.Com

保存并退出。hIT站長之家-易采站長站-Easck.Com

創建區域文件hIT站長之家-易采站長站-Easck.Com

創建你在 /etc/named.conf 文件中指定的轉發和反向區域文件:hIT站長之家-易采站長站-Easck.Com

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

添加以下行:hIT站長之家-易采站長站-Easck.Com

$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 文件:hIT站長之家-易采站長站-Easck.Com

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

添加以下行:hIT站長之家-易采站長站-Easck.Com

$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 譯注:本譯文中無法呈現粗體)內容都特定于你的環境。保存文件并退出。hIT站長之家-易采站長站-Easck.Com

你還需要配置 SElinux 并為配置文件添加正確的所有權。hIT站長之家-易采站長站-Easck.Com

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

配置防火墻:hIT站長之家-易采站長站-Easck.Com

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

檢查配置是否存在語法錯誤 hIT站長之家-易采站長站-Easck.Com

sudo named-checkconf /etc/named.conf

如果沒有輸出或返回錯誤,那么你的配置有效。hIT站長之家-易采站長站-Easck.Com

檢查轉發和反向區域文件。hIT站長之家-易采站長站-Easck.Com

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

你應該看到 “OK” 的響應:hIT站長之家-易采站長站-Easck.Com

zone forward.fedora.local/IN: loaded serial 2011071001 OK zone reverse.fedora.local/IN: loaded serial 2011071001 OKhIT站長之家-易采站長站-Easck.Com

啟用并啟動 DNS 服務 hIT站長之家-易采站長站-Easck.Com

$ sudo systemctl enable named
$ sudo systemctl start named

配置 resolv.conf 文件hIT站長之家-易采站長站-Easck.Com

編輯 /etc/resolv.conf 文件:hIT站長之家-易采站長站-Easck.Com

$ sudo vi /etc/resolv.conf

查找你當前的 nameserver 行。在示例系統上,使用調制解調器/路由器充當名稱服務器,因此當前看起來像這樣:hIT站長之家-易采站長站-Easck.Com

nameserver 192.168.1.1hIT站長之家-易采站長站-Easck.Com

這需要更改為主 DNS 服務器的 IP 地址:hIT站長之家-易采站長站-Easck.Com

nameserver 192.168.1.160hIT站長之家-易采站長站-Easck.Com

保存更改并退出。hIT站長之家-易采站長站-Easck.Com

不幸的是需要注意一點。如果系統重啟或網絡重啟,那么 NetworkManager 會覆蓋 /etc/resolv.conf 文件。這意味著你將丟失所做的所有更改。hIT站長之家-易采站長站-Easck.Com

為了防止這種情況發生,請將 /etc/resolv.conf 設為不可變:hIT站長之家-易采站長站-Easck.Com

$ sudo chattr +i /etc/resolv.conf

如果要重新設置,就需要允許其再次被覆蓋:hIT站長之家-易采站長站-Easck.Com

$ sudo chattr -i /etc/resolv.conf

測試 DNS 服務器 hIT站長之家-易采站長站-Easck.Com

$ 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 服務器實際上正常工作。hIT站長之家-易采站長站-Easck.Com

頂部的 QUERY、ANSWER 和 AUTHORITY 字段應顯示為非零,如我們的示例所示:hIT站長之家-易采站長站-Easck.Com

;; flags: qr rd ra; QUERY: 1, ANSWER: 1, AUTHORITY: 3, ADDITIONAL: 6hIT站長之家-易采站長站-Easck.Com

并且 SERVER 字段應有你的 DNS 服務器的 IP 地址:hIT站長之家-易采站長站-Easck.Com

;; SERVER: 192.168.1.160#53(192.168.1.160)hIT站長之家-易采站長站-Easck.Com

如果這是你第一次運行 dig 命令,請注意完成查詢要花費 830 毫秒的時間:hIT站長之家-易采站長站-Easck.Com

;; Query time: 830 msechIT站長之家-易采站長站-Easck.Com

如果再次運行它,查詢將會更快:hIT站長之家-易采站長站-Easck.Com

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

客戶端配置hIT站長之家-易采站長站-Easck.Com

客戶端配置將簡單得多。hIT站長之家-易采站長站-Easck.Com

安裝 bind 程序:hIT站長之家-易采站長站-Easck.Com

$ sudo dnf install bind-utils -yhIT站長之家-易采站長站-Easck.Com

編輯 /etc/resolv.conf 文件,并將主 DNS 配置為唯一的名稱服務器:hIT站長之家-易采站長站-Easck.Com

$ sudo vi /etc/resolv.confhIT站長之家-易采站長站-Easck.Com

它看起來像這樣:hIT站長之家-易采站長站-Easck.Com

nameserver 192.168.1.160hIT站長之家-易采站長站-Easck.Com

保存更改并退出。然后,使 /etc/resolv.conf 文件不可變,防止其被覆蓋并變回默認設置:hIT站長之家-易采站長站-Easck.Com

$ sudo chattr +i /etc/resolv.conf

測試客戶端hIT站長之家-易采站長站-Easck.Com

你應該獲得與 DNS 服務器相同的結果:hIT站長之家-易采站長站-Easck.Com

$ 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 地址。hIT站長之家-易采站長站-Easck.Com

你的 DNS 服務器設置完成了,現在所有來自客戶端的請求都會經過你的 DNS 服務器了!hIT站長之家-易采站長站-Easck.Com

為什么要搭建一個簡單的DNS服務器?hIT站長之家-易采站長站-Easck.Com

(1)當外網DNS崩潰,比如暴風門發生的那種情況,可以使用我們自己的DNS應急hIT站長之家-易采站長站-Easck.Com

(2)為內網網站提供內線的IP地址解析,或者實現雙線解析hIT站長之家-易采站長站-Easck.Com

(3)當你的ISP限制了二級域名和高級管理特性,你需要自己搭建DNS服務器來滿足自己的需要hIT站長之家-易采站長站-Easck.Com

(4)避免DNS劫持hIT站長之家-易采站長站-Easck.Com

(5)和別的解決方案集成hIT站長之家-易采站長站-Easck.Com

總結hIT站長之家-易采站長站-Easck.Com

到此這篇關于使用 bind 設置 DNS 服務器的文章就介紹到這了,更多相關bind dns服務器內容請搜索我們以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持我們!hIT站長之家-易采站長站-Easck.Com

hIT站長之家-易采站長站-Easck.Com

如有侵權,請聯系QQ:279390809 電話:15144810328

相關文章

  • Linux下用GHOST來做系統備份

    Linux下用GHOST來做系統備份

    在Windows系統下備份我們可以用GHOST工具軟件完成,Linux系統不能完全依賴于GHOST工具,一則是GHOST本身是有版權的軟件,二是GHOST只支持ext2、ext3文件系統的Linux分區,不支持reiserfs、xfs等
    2019-10-25
  • 給 FreeBSD 12.1 安裝 GNOME3 圖形界面

    給 FreeBSD 12.1 安裝 GNOME3 圖形界面

    FreeBSD是一個完全開放的、安全的系統,可以Do it yourself的系統。但是個人還是不喜歡呆板的命令行界面,所有就給 FreeBSD 12.1 安裝 GNOME3 圖形界面。 開始操作,啟動FreeBSD 12.1,以root身份
    2019-10-27
  • Ubuntu Studio一個不錯的操作系統

    Ubuntu Studio一個不錯的操作系統

    Ubuntu Studio 是一個基于 Ubuntu 而面向音頻、視頻及圖形愛好者的操作系統。本次推出的 Ubuntu Studio 為 7.04 版,目前僅支持 Intel i386 兼容的處理器。 Ubuntu Studio 從大量的開源多媒體創作程序
    2019-10-25
  • 最受歡迎的10款Linux免費游戲

    最受歡迎的10款Linux免費游戲

    圖為在Linux下運行的免費游戲America's Army 如果你認為 Linux下沒有什么好游戲的話,那就錯了!我們來看看Linux下最受歡迎的10款游戲吧,而且這些游戲都是完全免費的! # skyreal update(06-12
    2019-10-25
  • compiz fusion特效使用心得(附3D桌面圖)

    compiz fusion特效使用心得(附3D桌面圖)

    3D桌面圖 LINUX發行版就是好,當大多數人還在沉迷于那些什么風格圖標鳥玻璃效果甚至孜孜不倦津津樂道的時候,Linux的高手們已經悄悄為我們開啟了一個桌面系統3D的時代。 當我第一次
    2019-10-25
  • Ubuntu 下aMule 的安裝配置

    Ubuntu 下aMule 的安裝配置

    aMule 是一個類似于 eMule 的多平臺 P2P 客戶端程序。以下將簡略敘述 aMule 在 Ubuntu 中的安裝及配置 [High ID] 與 [KAD] 的過程。 安裝: sudo apt-get install amule sudo apt-get install amule-utils 如果需要
    2019-10-25
  • JMeter jp@gc - stepping thread group插件

    JMeter jp@gc - stepping thread group插件

    這是一個出單接口壓力測試的小例子,了解一下壓力測試最最基礎的基礎。出單接口是用來保險出單的,不需要在UI界面下一步下一步的出單,接口一調數據入庫完事~~~。再啰嗦一句接
    2019-10-27
  • Ubuntu 下使用K3B軟件刻錄光盤(圖)

    Ubuntu 下使用K3B軟件刻錄光盤(圖)

    不知大家會不會在Ubuntu下刻錄光盤呢?k3b是KDE環境下的一個CD/DVD刻錄軟件,有非常容易使用的界面,功能比較齊全。用起來感覺就象是win下的Nero一樣簡單自然,比ubuntu里原來的刻錄CD方式
    2019-10-25
色七七影院_香港三级台湾三级在线播放_男人放进女人阳道猛进猛出