目前Linux操作系統(tǒng)十分火爆,所以很多朋友希望了解一下Linux下虛擬域名的實現(xiàn)過程。下面就基于目前比較流行的RedHat來討論一下。
一、DNS服務(wù)器的設(shè)置
我們知道互聯(lián)網(wǎng)網(wǎng)是基于TCP/IP協(xié)議的,要進行通信必須獲得對方的IP地址,這是通過DNS服務(wù)器來實現(xiàn)的。因此要想實現(xiàn)虛擬域名首先應(yīng)當(dāng)令DNS服務(wù)器接受該虛擬域名,即把它映射到指定的IP地址上。因為我們靠Web服務(wù)器來區(qū)分域名,所以這個IP地址自然應(yīng)當(dāng)是Web服務(wù)器所管理的。
RedHat6.0操作系統(tǒng)中捆綁有BIND DNS服務(wù)器。它的域名配置文件是"/etc/named.conf",一般情況下,域配置文件放在"/var/named"目錄下面。
例1、named.conf文件的配置:
zone "domain.com" {
type master;
file "domain.com";
};
zone "0.10.10.in-addr.arpa" {
type master;
file "10.10.0";
};
該例子說明"domain.com"的域配置文件是"/var/named/domain.com",反向域的配置文件是"/var/named/10.10.0"。domain.com文件負責(zé)把DNS域名映射為IP地址。
例2、domain.com文件配置:
@ IN SOA dns.domain.com. hostmaster.dns.domain.com. (
1998111003 ; serial
3600 ; refresh
900 ; retry
1209600 ; expire
43200 ; default_ttl
)
@ IN MX 10 dns.domain.com.
@ IN NS dns.domain.com.
@ IN A 10.10.0.1
www IN A 10.10.0.1
假定要增加的域名是aaa.domain.com,想要指到www.domain.com,DNS服務(wù)中應(yīng)增加一個別名記錄,可寫成:
aaa IN CNAME www.domain.com.
如果需要配置大量的虛擬域名,domain.com文件要很大,而且也相當(dāng)麻煩。我們可以使用符號 "*" ,即在 domain.com 文件中加入:
* IN CNAME www.domain.com.
這樣它就把所有沒給出設(shè)置的以domain.com結(jié)尾的記錄全部轉(zhuǎn)到www.domain.com去了,不管是aaa.domain.com還是bbb.domain.com。這不會影響已有的記錄。配置好DNS服務(wù)器后應(yīng)該重新啟動守護進程named:
[root@domain /root]# /etc/rc.d/init.d/named restart
二、Apache服務(wù)器的配置
Apache服務(wù)器是目前互聯(lián)網(wǎng)上使用最多的Web服務(wù)器,它可以維護非常繁忙的站點。RedHat 6.0捆綁了Apache Web Server 1.3。它的配置文件位于"/etc/httpd/conf"目錄下,有httpd.conf、srm.conf、access.conf,下面討論一下與虛擬域名有關(guān)的配置:
1、靜態(tài)配置
修改配置文件 httpd.conf 的步驟:
(1) 首先設(shè)置UseCanonicalName為off。它指示用服務(wù)器Host:header的內(nèi)容代替ServerName 的值來提供給環(huán)境變量SERVER_NAME。
(2) 然后加入:
NameVirtualHost xxx.xxx.xxx.xxx其中xxx.xxx.xxx.xxx為所要配置的虛擬服務(wù)器的IP地址。在此可配置多個虛擬IP地址,當(dāng)然要與DNS服務(wù)器中的配置一致。(注意:這里要用IP地址,不能用域名。)
(3) 接下來為每個虛擬域名加入一段記錄:
< virtualhost xxx.xxx.xxx.xxx>
.....
< /virtualhost>
xxx.xxx.xxx.xxx要和NameVirtualHost配置的IP地址一致。在兩個標(biāo)志之間可加入的配置參數(shù)有:
ServerName后面跟你要增加的虛擬域名,如aaa.domain.com ;
Documentroot如果你映射到本機的路徑就加在后面,如"/home/aaa" ;
redirect如果你映射到遠端的URL可加在后面,有兩個參數(shù),第一個是虛擬域名的相對路徑,第二個是遠端站點的URL;
ServerAlias后可加入本域名的別名,可使用通配符,如*.aaa.domain.com 。
下面舉兩個例子:
例3、映射到本機的物理路徑:
< virtualhost xxx.xxx.xxx.xxx>
DocumentRoot "/home/test"
ServerName test.domain.com
< virtualhost>
例4、映射到遠端的URL:
< virtualhost xxx.xxx.xxx.xxx>
ServerName test1.doamin.com
redirect / http://test.domain1.com/welcome.htm
< /virtualhost>
還有一些參數(shù),象log文件的位置、超時的設(shè)置、緩沖區(qū)的設(shè)置等等,在此不一一介紹,可以參考Apache服務(wù)器的在線幫助文件。配置好httpd.conf文件后需要重新啟動Apache的后臺守護進程httpd,
[root@domain /root]# /etc/rc.d/init.d/httpd restart
每增加一個虛擬域名就要增加一段位于 < VirtualHost...>...< /VirtualHost> 之間的配置代碼,而且只有在重新啟動 httpd 后新配置才能生效。
2、動態(tài)配置
可以發(fā)現(xiàn),如果要配置大量的虛擬域名將大大增加配置文件的長度,這樣還會使Apache啟動變慢,占用更多的內(nèi)存,而且也不容易實現(xiàn)在線申請。可以通過選擇動態(tài)方式來配置。這樣不必事先寫好配置,而是通過編寫一定的動態(tài)規(guī)則來自動生成或隨時從獨立的配置文件中讀取信息。
Apache有一個強大的擴展功能,即模塊(Modules)的特性。模塊可對服務(wù)器的功能進行擴充,它在運行和使用時才裝入服務(wù)器,這樣比一直放入服務(wù)器中要節(jié)省內(nèi)存空間,同時也比調(diào)用外部CGI程序速度快。
現(xiàn)在使用一個功能強大的模塊來實現(xiàn)動態(tài)配置虛擬域名,這就是mod_rewrite。它負責(zé)偵聽從客戶機送出的URL地址,并基于一組規(guī)則表達式對該URL來進行重寫。這類似于URL別名概念,但它更進了一步,輸出的URL可以映射到其他主機的任何URL地址上。 修改配置文件httpd.conf的步驟:
(1) 先設(shè)置UseCanonicalName為off 。
(2) 使用RewriteEngine on打開rewrite引擎。用RewriteMap設(shè)定配置文件的位置和屬性,用RewriteCond和RewriteRule制定相應(yīng)的規(guī)則。
例5、httpd.conf 文件中相關(guān)配置的一個例子:
RewriteEngine on
RewriteMap lowercase int:tolower
# 定義獨立的配置文件的位置
RewriteMap vhost dbm:/www/conf/vhostdbm
# 利用獨立的配置文件重映射虛擬域名
RewriteCond ${vhost:%1} ^(/.*)$
RewriteRule ^/(.*)$ %1/docs/$1
RewriteCond %{REQUEST_URI} ^/cgi-bin/
RewriteCond ${lowercase:%{SERVER_NAME}} ^(.+)$
RewriteCond ${vhost:%1} ^(/.*)$
RewriteRule ^/(.*)$ %1/cgi-bin/$1
這里的 vhostdbm 文件格式見"CGI 程序的編制" 。
三、CGI程序的編制
要實現(xiàn)虛擬域名的在線申請,就必須編寫相應(yīng)CGI程序動態(tài)修改獨立的配置文件(即上面的vhostdbm文件)和進行用戶的管理(包括用戶申請,登錄,密碼修改等等)。在此只介紹對獨立的配置文件的操作,其他屬于如何用Perl語言來編寫CGI程序,請參考有關(guān)資料。
vhostdbm文件使用dbm格式來記錄數(shù)據(jù),與用普通文本文件相比可加快尋找速度,而且易于修改。許多UNIX系統(tǒng)都具有叫做dbm(database management)的標(biāo)準庫。該庫將鍵-值對的集合存貯到一對磁盤文件中,提供簡單的數(shù)據(jù)庫管理工具,可以方便的更改、新增或刪除數(shù)據(jù)內(nèi)容。
Perl訪問dbm的方式:通過一個類似于打開文件的進程將關(guān)聯(lián)數(shù)組與dbm數(shù)據(jù)庫聯(lián)系起來。在數(shù)組中創(chuàng)建新元素時立即就更改了dbm數(shù)據(jù)庫。刪除一個元素的同時也刪除了dbm數(shù)據(jù)庫中的數(shù)值??墒褂茫?
1、欲將dbm數(shù)據(jù)庫與dbm數(shù)組相關(guān)聯(lián)起來:
dbmopen(%arrayname,"dbmfilename",$mode);
如果dbmfilename不存在的話就新建該庫。%arrayname參數(shù)是Perl的關(guān)聯(lián)數(shù)組(如果這個數(shù)組已經(jīng)有值,那么這些值就被刪除)。該關(guān)聯(lián)數(shù)組連接到叫做dbmfilename的dbm數(shù)據(jù)庫中。$mode 參數(shù)是當(dāng)需要創(chuàng)建庫時控制庫文件權(quán)限的數(shù)字,該數(shù)字被指定為8制,經(jīng)常被用到的是0644,給除了機主之外的新用戶以只讀的權(quán)限,機主可有全部權(quán)限。
2、關(guān)閉dbm庫:
dbmclose(%arrayname);
%arrayname 是已經(jīng)與dbm庫關(guān)聯(lián)了的數(shù)組名。
例6、VHOST打開vhostdbm,或新建一個dbm庫:
dbmopen(%VHOST,"vhostdbm",0644);
例7、新建記錄或更改已有記錄(設(shè)從html文件form中傳過來的參數(shù)名為vhost、rhost):
$VHOST{$FORM{'vhost'}}=$FORM{'rhost'};
例8、刪除已有記錄(設(shè)從html文件form中傳過來的參數(shù)名為vhost):
delete $VHOST{$FORM{'vhost'}};
例9、關(guān)閉vhostdbm:
dbmclose(%VHOST);
注:以上已經(jīng)假設(shè)傳過來的參數(shù)經(jīng)過了驗證,不存在重復(fù)的記錄,否則會導(dǎo)致已有記錄的混亂。
------------------------------- · 相關(guān)文檔瀏覽 · --------------------------------------------------------------------- · 熱門文檔瀏覽 · -------------------------------------