Windows XP Windows 7 Windows 2003 Windows Vista Windows教程綜合 Linux 系統教程
Windows 10 Windows 8 Windows 2008 Windows NT Windows Server 電腦軟件教程
 Windows教程網 >> 電腦軟件教程 >> 服務器技術 >> DNS服務器 >> 詳解Linux下動態DNS服務配置

詳解Linux下動態DNS服務配置

日期:2017/1/20 17:50:47      編輯:DNS服務器

在網絡管理中,對於DNS服務的管理是一項基礎性的工作。隨著用戶規模的擴大,頻繁地手工修改DNS的區域數據庫文件不是一件輕松的工作。關於動態DNS(DDNS)的研究逐漸引起了人們的關注,不同的平台都推出了自己的解決方案。本文將詳細介紹Linux環境下DDNS的解決方案,即由Internet Software Consortium(ISC)開發的BIND-DNS和DHCP(Dynamic Host Configure Protocol,動態主機配置協議)協同工作,進而共同實現DDNS的方法。

在Linux下實現動態DNS不僅需要Bind 8以上的DNS軟件,還要有DHCP Server v3.0以上版本,因為只有3.0以上的版本才完全實現了對DDNS的支持。因此,本文的實現環境采用Slackware Linux 9.0作為DDNS服務器,其上同時運行DNS和DHCP服務,其中DNS Server采用Bind 9.2.2,DHCP Server采用DHCP Server v3.0pl2。

下面詳細介紹Linux環境下安全、動態DNS的實現方法。

創建密鑰

要實現DNS的動態更新,首先要考慮的是怎樣保證安全地實現DDNS。由ISC給出的方法是創建進行動態更新的密鑰,在進行更新時通過該密鑰加以驗證。為了實現這一功能,需要以root身份運行以下命令:

root@slack9:/etc# dnssec-keygen -a HMAC-MD5 -b 128 -n USER myddns

Kmyddns.+157+37662

上述dnssec-keygen命令的功能就是生成更新密鑰,其中參數-a HMAC-MD5是指密鑰的生成算法采用HMAC-MD5;參數-b 128是指密鑰的位數為128位;參數-n USER myddns是指密鑰的用戶為myddns。

該命令生成的一對密鑰文件如下:

-rw------- 1 root root 48 Jan 14 18:26 Kmyddns.+157+37662.key

-rw------- 1 root root 81 Jan 14 18:26 Kmyddns.+157+37662.private

可以查看剛生成的密鑰文件內容:

root@slack9:/etc# cat Kmyddns.+157+37662.key

myddns.INKEY02157 4gEF1Mkmn5hrlwYUeGJV3g==

root@slack9:/etc# cat Kmyddns.+157+37662.private

Private-key-format: v1.2

Algorithm: 157 (HMAC_MD5)

Key: 4gEF1Mkmn5hrlwYUeGJV3g==  

仔細閱讀該密鑰文件就會發現,這兩個文件中包含的密鑰是一樣的,該密鑰就是DHCP對DNS進行安全動態更新時的憑據。後面需要將該密鑰分別添加到DNS和DHCP的配置文件中。

修改DNS的主配置文件

密鑰生成後就要開始對/etc/named.conf文件進行編輯修改,主要目的是將密鑰信息添加到DNS的主配置文件中。本文給出修改後的/etc/named.conf的一個實例:

options {
   directory "/var/named";
   file://指定區域數據庫文件的存放目錄
   };
   zone "." IN {
   type hint;
   file "caching-example/named.ca";
   };
   zone "localhost" IN {
   type master;
   file "caching-example/localhost.zone";
   allow-update { none; };
   };
   zone "0.0.127.in-addr.arpa" IN {
   type master;
   file "caching-example/named.local";
   allow-update { none; };
   };
   key myddns {
   algorithm HMAC-MD5.SIG-ALG.REG.INT;
   file://指明生成密鑰的算法
   secret 4gEF1Mkmn5hrlwYUeGJV3g==;
   file://指明密鑰
   };
   zone "tcbuu.cn" IN {
   type master;
   file "tcbuu.cn";
   file://正向區域文件名tcbuu.cn,後文會用到該文件
   allow-update { key myddns; };
   file://指明采用key myddns作為密鑰的用戶可以動態更新該區域“tcbuu.cn”
   };
   zone "1.22.10.in-addr.arpa" IN {
   type master;
   file "tcbuu.cn.arpa";//反向區域文件名tcbuu.cn
   allow-update { key myddns; };
   file://指明采用key myddns作為密鑰的用戶可以動態更新該區域“1.22.10.in-addr.arpa”
   };

在/etc/named.conf中可以定義多個區域,只要在允許動態更新的區域中增加allow-update { key myddns; }指令,即可實現動態更新,並且只有擁有key myddns實體(在本文的實現中該實體就是擁有同樣密鑰的DHCP服務器)才能實現對該區域進行安全地動態更新。相比原來只限定IP地址的方法,該方法要安全得多。

至此完成對DNS服務器的配置,可以執行#named運行DNS服務。

Copyright © Windows教程網 All Rights Reserved