subnet 192.168.0.0 netmask 255.255.255.0{
range 192.168.0.10 192.168.0.100;
}
說明:
缺省每個IP租期2天: default-lease-time 120000;
最長租期: max-lease-time 920000;
缺省子網掩碼:option subnet-mask 255.255.255.0;
缺省廣播地址:option broadcast-address 192.168.0.255;
讓192.168.0.200上的samba服務啟用WINS服務:用于內部域名解析:option netbios-name-servers 192.168.0.200;
缺省網關 option routers 192.168.0.1;
缺省域名服務器 option domain-name-servers 202.106.196.115,202.96.199.133;
缺省域名 option domain-name "example.com";
#一個缺省的子網設置:
subnet 192.168.0.0 netmask 255.255.255.0{
#為子網動態分配0.10-100的IP
range 192.168.0.10 192.168.0.100;
}
輔DHCP服務器上唯一不同的地方是:為子網動態分配0.110-150的IP,主DHCP和附DHCP服務器的IP池不能相互重疊
subnet 192.168.0.0 netmask 255.255.255.0{
range 192.168.0.110 192.168.0.150;
}
3、主服務器上的應用安裝
SAMBA服務:用于文件的共享和內部WINS解析,這里只做一個只讀共享的簡單配置:
[global]
#別人會通過"網上鄰居"看到WORKGROUP組里的
Linux機器,注釋是:My Samba Server
workgroup = WORKGROUP
netbios name = Linux
server string = My Samba Server
#日志設置
log file = /var/log/samba/%m.log
max log size = 50
#安全設置
security = share
#用SAMBA的WINS服務支持,并且用/etc/hosts做內部域名解析
wins support = yes
name resolve order = hosts lmhosts wins bcast
dns proxy = yes
[public]
#一個共享設置
comment = Public Stuff
path = /home/share
public = yes
guest ok = yes
read only = yes
writable = no
printable = no
在這里為了讓大家能夠在內部使用dev.example.com訪問主服務器(192.168.0.200),我用DHCP設置主服務器(192.168.0.200)同時也是是內部的WINS服務器,而在200的SAMBA服務中,啟用了WINS支持,并設置WINS用可以利用DNS做NETBIOS名稱解析。這樣如果DNS讀取的是/etc/hosts文件中的設置的話,hosts文件就可以當作WINS域名配置文件了,在/etc/hosts里設置:
192.168.0.200 dev.example.com bbs.example.com dev bbs
192.168.0.201 bak.example.com backup
通過DHCP獲得IP的內網客戶端就可以直接通過: dev.example.com訪問開發服務器了。
所有的機器名前綴我都使用了縮寫:dev, bbs bak之類的,原因是samba的NMBD實際上是NETBIOS名稱的解析,名稱長度是16個字符(實際是15個)有限制的。因此,雖然192.168.0.202 username.example.com雖然是一個合法的DNS名稱解析,但由于username.example.com長度超過了16個字符,所以通過SAMBA的WINS服務解析仍然無法找到。dev.chedong.com相當于\dev.chedong.com這樣的一臺機器。當初用SAMBA的WINS解析在客戶端總是ping不通testing.chedong.com這個問題困擾了我好一陣。
4、Web服務:Apache
主要用作文件的WEB共享和一些應用的前端瀏覽(CVSWEB GNATSWEB PHPMYADMIN等),Apache,這里仍然使用了1.3,因為很多應用,比如PHP在2.0上運行還不是完整。
安裝:http://httpd.apache.org下載最新版本:
編譯選項:這樣可以讓所有的模塊都通過配置文件動態加載,方便后面其他應用模塊的添加刪除:
./configure --prefix=/home/apache --enable-shared=max --enable-module=most
更多安裝說明可以參考: APACHE安裝筆記。
文檔共享技巧:
1、對于文檔的共享來說,autoindex模塊非常有用,讓APACHE自動索引目錄缺省是按文件/目錄名排序的,而且文件名40個字符以上部分是被截斷的,為了能顯示完整的文件名,并且像資源管理器那樣將目錄排在前面,文件排在后面:
在模塊設置中:
#增加NameWidth選項,并且文件名長度是*(自動適應當前目錄下最長文件名)
#增加FoldersFirst選項,讓目錄列在前面(類似于資源管理器)
#增加了ScanHTMLTitles用HTML文件的TITLE做文件
#的描述,并設置描述長度是*(自適應最長)
IndexOptions FancyIndexing +NameWidth=*
FoldersFirst ScanHTMLTitles +DescriptionWidth=*
2、如果是CGI開發,如何讓用戶在自己的目錄下能夠發布CGI程序,比如:http://192.168.0.200/~chedong/cgi-bin/my_cgi:在模塊設置中,添加正則表達式: ScriptAliasMatch ~([a-z]+)/cgi-bin/(.*) /home/$1/cgi-bin/$2意思是匹配~user_name/cgi-bin/cgi_name自動映射到/home/user_name/cgi-bin/cgi-name腳本。
5、版本控制:CVS
CVS缺省在服務器上幾乎都安裝好了,只要按照以下步驟初始化即可:
在/etc/profile里:
CVS庫所在的主服務器設置:
export CVSROOT=/home/cvsroot
在其他開發服務器里設置:
export CVSROOT=:ext:$USER@192.168.0.200:/home/cvsroot
export CVS_RSH=ssh
然后在主服務器上cvs init初始化:
關于CVSWEB的設置,重復以下CVS常用命令手冊中CVSWEB的內容:
CVSWEB的下載:CVSWEB從最初的版本已經演化出很多功能界面更豐富的版本,這個是個人感覺安裝設置比較方便的: http://www.spaghetti-code.de/software/linux/cvsweb/
下載解包:
tar zxf cvsweb.tgz
把配置文件cvsweb.conf放到安全的地方(比如和apache的配置放在同一個目錄下),
修改:cvsweb.cgi讓CGI找到配置文件:
$config = $ENV{'CVSWEB_CONFIG'}'
''/path/to/apache/conf/cvsweb.conf';
轉到/path/to/apache/conf下并修改cvsweb.conf:
修改CVSROOT路徑設置:
%CVSROOT = (
'Development' => '/path/to/cvsroot',
#<==修改指向本地的CVSROOT
);
缺省不顯示已經刪除的文檔:
"hideattic" => "1",#<==缺省不顯示已經刪除的文檔。
在配置文件cvsweb.conf中還可以定制頁頭的描述信息,你可以修改$long_intro成你需要的文字。
首先可以CVS進庫里的就是以上系統的安裝文檔。
更多的關于CVS的擴展應用可以參考CVS常用命令手冊CVSTRAC部分。
6、多個服務之間的資源共享
一般可以通過鏈接解決,比如:我希望匿名ftp共享的內容(比如在/var/ftp/pub目錄下)都可以WEB發布:
ln -s /var/ftp/pub /home/apache/htdocs/pub
我希望/usr/share/doc里的文檔大家可以通過WEB瀏覽:
ln -s /usr/share/doc /home/apache/htdocs/doc
我希望WEB發布的內容大家通過WINDOWS網絡鄰居也可以訪問:假設/home/share是samba發布的只讀共享路徑:
ln -s /home/apache/htdocs /home/share
服務的自動啟動:
系統已經安裝的服務一般可以通過setup的服務配置是否自動啟動,否則就在/etc/rc.local里加一些啟動腳本即可。
比如:備份和日志統計可以將以下腳本寫在主服務器的ROOT的CRON里:
#time sync
0 5 * * 1 (/usr/bin/rdate -s YOUR_DATE_TIME_SERVER)
#backup gnats
6 3 * * * (cd /home; tar cf
/home/backup/gnats.`date +\%w`.tar gnats)
#backup cvsroot
5 3 * * * (cd /home; tar cf
/home/backup/cvsroot.`date +\%w`.tar cvsroot)
#backup apache
8 3 * * * (cd /home; tar cf
/home/backup/apache.`date +\%w`.tar apache)
#gzip all backup
50 3 * * * (gzip -f /home/backup/*.tar)
#webalizer demo
3 5 * * * (/usr/local/bin/webalizer -c /home/apache/conf/webalizer.conf
/home/apache/logs/`date -d yesterday +%w`/aclearcase/" target="_blank" >ccess_log)
#remove last week log
3 4 * * * (find /home/apache/logs/ -name
access_log -mtime +6 -exec rm -f {};)
這樣,在/home/backup目錄下會有按星期輪訓的7個備份。然后通過在輔助服務器上設置CRON用wget的-m選項鏡像主服務器上的/home/backup目錄或者用rsync做同步就可以了。后面的2條是關于使用webalzier做服務器的日志統計,APACHE的日志通過cronolog進行了輪循。