Apache服務的主要目錄和配置文件詳解
一、Apache 主要配置文件注釋
Apache的主配置文件:/etc/httpd/conf/httpd.conf
默認站點主目錄:/var/www/html/
Apache服務器的配置信息全部存儲在主配置文件/etc/httpd/conf/httpd.conf中,這個文件中的內(nèi)容非常多,用wc命令統(tǒng)計一共有1009行,其中大部分是以#開頭的注釋行。
ServerTokens OS
在出現(xiàn)錯誤頁的時候是否顯示服務器操作系統(tǒng)的名稱,ServerTokens Prod為不顯示
ServerRoot "/etc/httpd"
用于指定Apache的運行目錄,服務啟動之后自動將目錄改變?yōu)楫斍澳夸?,在后面使用到的所有相對路徑都是想對這個目錄下
User daemon # apache的用戶,默認為daemon Group daemon # apache的用戶,默認為daemon PidFile run/httpd.pid
記錄httpd守護進程的pid號碼,這是系統(tǒng)識別一個進程的方法,系統(tǒng)中httpd進程可以有多個,但這個PID對應的進程是其他的父進程
Timeout 60
服務器與客戶端斷開的時間
KeepAlive Off
是否持續(xù)連接(因為每次連接都得三次握手,如果是訪問量不大,建議打開此項,如果網(wǎng)站訪問量比較大關閉此項比較好),修改為:KeepAlive On 表示允許程序性聯(lián)機
MaxKeepAliveRequests 100
表示一個連接的最大請求數(shù)
KeepAliveTimeout 15
斷開連接前的時間
<IfModule prefork.c> StartServers 8 MinSpareServers 5 MaxSpareServers 20 ServerLimit 256 MaxClients 256 MaxRequestsPerChild 4000 </IfModule>
系統(tǒng)默認的模塊,表示為每個訪問啟動一個進程(即當有多個連接公用一個進程的時候,在同一時刻只能有一個獲得服務)。
StartServer開始服務時啟動8個進程,最小空閑5個進程,最多空閑20個進程。
MaxClient限制同一時刻客戶端的最大連接請求數(shù)量超過的要進入等候隊列。
MaxRequestsPerChild每個進程生存期內(nèi)允許服務的最大請求數(shù)量,0表示永不結(jié)束
<IfModule worker.c> StartServers 4 MaxClients 300 MinSpareThreads 25 MaxSpareThreads 75 ThreadsPerChild 25 MaxRequestsPerChild 0 </IfModule>
為Apache配置線程訪問,即每對WEB服務訪問啟動一個線程,這樣對內(nèi)存占用率比較小。
ServerLimit服務器允許配置進程數(shù)的上限。
ThreadLimit每個子進程可能配置的線程上限
StartServers啟動兩個httpd進程,MaxClients同時最多能發(fā)起250個訪問,超過的要進入隊列等待,其大小有ServerLimit和ThreadsPerChild的乘積決定
ThreadsPerChild每個子進程生存期間常駐執(zhí)行線程數(shù),子線程建立之后將不再增加
MaxRequestsPerChild每個進程啟動的最大線程數(shù),如達到限制數(shù)時進程將結(jié)束,如置為0則子線程永不結(jié)束
Listen 80
監(jiān)聽的端口,如有多塊網(wǎng)卡,默認監(jiān)聽所有網(wǎng)卡
LoadModule auth_basic_module modules/mod_auth_basic.so
......
LoadModule version_module modules/mod_version.so
啟動時加載的模塊
Include conf.d/*.conf
加載的配置文件
啟動服務后轉(zhuǎn)換的身份,在啟動服務時通常以root身份,然后轉(zhuǎn)換身份,這樣增加系統(tǒng)安全
ServerAdmin root@localhost #管理員的郵箱,如果出現(xiàn)問題,會在首頁顯示
#ServerName www.example.com:80
默認是不需要指定的,服務器通過名字解析過程來獲得自己的名字,但如果解析有問題(如反向解析不正確),或者沒有DNS名字,也可以在這里指定IP地址,當這項不正確的時候服務器不能正常啟動。前面啟動Apache時候提示正在啟動 httpd:httpd: apr_sockaddr_info_get() failed forjustin httpd: Could not reliably determine the server's fully qualified domain name, using 127.0.0.1forServerName,解決方法就是啟動該項把www.example.com:80修改為自己的域名或者直接修改為localhost
UseCanonicalName Off
如果客戶端提供了主機名和端口,Apache將會使用客戶端提供的這些信息來構(gòu)建自引用URL。這些值與用于實現(xiàn)基于域名的虛擬主機的值相同,并且對于同樣的客戶端可用。CGI變量SERVER_NAME和SERVER_PORT也會由客戶端提供的值來構(gòu)建
DocumentRoot "/var/www/html" # apache的默認web站點目錄路徑,結(jié)尾不要添加斜線
<Directory /> #行為對根目錄的限制 Options FollowSymLinks # followsymlinks表示允許使用符號鏈接,默認為禁用 AllowOverride None # 表示禁止用戶對目錄配置文件(.htaccess進行修改)重載,普通站點不建議開啟 </Directory> <Directory "/var/www/html"> Options Indexes FollowSymLinks AllowOverride None Order allow,deny Allow from all </Directory>
對/var/www/html目錄的一個權(quán)限的設置,options中Indexes表示當網(wǎng)頁不存在的時候允許索引顯示目錄中的文件,F(xiàn)ollowSymLinks是否允許訪問符號鏈接文件。有的選項有ExecCGI表是否使用CGI,如Options Includes ExecCGI FollowSymLinks表示允許服務器執(zhí)行CGI及SSI,禁止列出目錄。SymLinksOwnerMatch表示當符號鏈接的文件和目標文件為同一用戶擁有時才允許訪問。AllowOverrideNone表示不允許這個目錄下的訪問控制文件來改變這里的配置,這也意味著不用查看這個目錄下的訪問控制文件,修改為:AllowOverride All 表示允許.htaccess。Order對頁面的訪問控制順序后面的一項是默認選項,如allow,deny則默認是deny,Allowfromall表示允許所有的用戶,通過和上一項結(jié)合可以控制對網(wǎng)站的訪問控制
<IfModule mod_userdir.c> UserDir disabled </IfModule>
是否允許用戶訪問其家目錄,默認是不允許
#<Directory /home/*/public_html> # AllowOverride FileInfo AuthConfig Limit # Options MultiViews Indexes SymLinksIfOwnerMatch IncludesNoExec # <Limit GET POST OPTIONS> # Order allow,deny # Allow from all # </Limit> # <LimitExcept GET POST OPTIONS> # Order deny,allow # Deny from all # </LimitExcept> #</Directory>
如果允許訪問用戶的家目錄中的網(wǎng)頁文件,則取消以上注釋,并對其中進行修改
DirectoryIndex index.html index.html.var #指定所要訪問的主頁的默認主頁名字,默認首頁文件名為index.html
AccessFileName .htaccess #定義每個目錄下的訪問控制文件名,缺省為.htaccess
<Files ~ "^\.ht"> Order allow,deny Deny from all Satisfy All </Files>
控制不讓web上的用戶來查看.htpasswd和.htaccess這兩個文件
TypesConfig /etc/mime.types #用于設置保存有不同MIME類型數(shù)據(jù)的文件名
DefaultType text/plain #默認的網(wǎng)頁的類型
<IfModule mod_mime_magic.c> # MIMEMagicFile /usr/share/magic.mime MIMEMagicFile conf/magic </IfModule>
指定判斷文件真實MIME類型功能的模塊
HostnameLookups Off #當打開此項功能時,在記錄日志的時候同時記錄主機名,這需要服務器來反向解析域名,增加了服務器的負載,通常不建議開啟
#EnableMMAP off
是否允許內(nèi)存映射:如果httpd在傳送過程中需要讀取一個文件的內(nèi)容,它是否可以使用內(nèi)存映射。如果為on表示如果操作系統(tǒng)支持的話,將使用內(nèi)存映射。在一些多核處理器的系統(tǒng)上,這可能會降低性能,如果在掛載了NFS的DocumentRoot上如果開啟此項功能,可能造成因為分段而造成httpd崩潰
#EnableSendfile off
這個指令控制httpd是否可以使用操作系統(tǒng)內(nèi)核的sendfile支持來將文件發(fā)送到客戶端。默認情況下,當處理一個請求并不需要訪問文件內(nèi)部的數(shù)據(jù)時(比如發(fā)送一個靜態(tài)的文件內(nèi)容),如果操作系統(tǒng)支持,Apache將使用sendfile將文件內(nèi)容直接發(fā)送到客戶端而并不讀取文件
ErrorLog logs/error_log #錯誤日志存放的位置 LogLevel warn #Apache日志的級別
LogFormat "%h %l %u %t \"%r\" %>s %b \"%{Referer}i\" \"%{User-Agent}i\"" combined LogFormat "%h %l %u %t \"%r\" %>s %b" common LogFormat "%{Referer}i -> %U" referer LogFormat "%{User-agent}i" agent
定義了日志的格式,并用不同的代號表示
#CustomLog logs/access_log common CustomLog logs/access_log combined
說明日志記錄的位置,這里面使用了相對路徑,所以ServerRoot需要指出,日志位置就存放在/etc/httpd/logs
ServerSignature On #定義當客戶請求的網(wǎng)頁不存在,或者錯誤的時候是否提示apache的版本的一些信息
Alias /icons/ "/var/www/icons/" #定義一些不在DocumentRoot下的文件,而可以將其映射到網(wǎng)頁根目錄中,這也是訪問其他目錄的一種方法,但在聲明的時候切記目錄后面加”/”
<Directory "/var/www/icons"> Options Indexes MultiViews FollowSymLinks AllowOverride None Order allow,deny Allow from all </Directory>
定義對/var/www/icons/的權(quán)限,修改為 Options MultiViews FollowSymLinks表示不在瀏覽器上顯示樹狀目錄結(jié)構(gòu)
<IfModule mod_dav_fs.c> # Location of the WebDAV lock database. DAVLockDB /var/lib/dav/lockdb </IfModule>
對mod_dav_fs.c模塊兒的管理
ScriptAlias /cgi-bin/ "/var/www/cgi-bin/" #對CGI模塊兒的的別名,與Alias相似
<Directory "/var/www/cgi-bin"> AllowOverride None Options None Order allow,deny Allow from all </Directory>
對/var/www/cgi-bin文件夾的管理,方法同上
# Redirect old-URI new-URL
Redirect參數(shù)是用來重寫URL的,當瀏覽器訪問服務器上的一個已經(jīng)不存在的資源的時候,服務器返回給瀏覽器新的URL,告訴瀏覽器從該URL中獲取資源。這主要用于原來存在于服務器上的文檔改變位置之后,又需要能夠使用老URL能訪問到原網(wǎng)頁
IndexOptions FancyIndexing VersionSort NameWidth=* HTMLTable Charset=UTF-8
AddIconByEncoding (CMP,/icons/compressed.gif) x-compress x-gzip
...
IndexIgnore .??* *~ *# HEADER* README* RCS CVS *,v *,t
當一個HTTP請求的URL為一個目錄的時候,服務器返回這個目錄中的索引文件,如果目錄中不存在索引文件,并且服務器有許可顯示目錄文件列表的時候,就會顯示這個目錄中的文件列表,為了使得這個文件列表能具有可理解性,而不僅僅是一個簡單的列表,就需要前這些參數(shù)。如果使用了IndexOptionsFancyIndexing選項,可以讓服務器針對不同的文件引用不同的圖標。如果沒有就使用DefaultIcon定義缺省圖標。同樣,使用AddDescription可以為不同類型的文檔介入描述
AddLanguage ca .ca
......
AddLanguage zh-TW .zh-tw
添加語言
LanguagePriority en ca cs da de el eo es et fr he hr it ja ko ltz nl nn no pl pt pt-BR ru sv zh-CN zh-TW
Apache支持的語言
AddDefaultCharset UTF-8 #默認支持的語言
#AddType application/x-tar .tgz #支持的應用如果想支持對php的解析添加這樣一行 #AddEncoding x-compress .Z #AddEncoding x-gzip .gz .tgz
支持對以.Z和.gz.tgz結(jié)尾的文件
AddType application/x-compress .Z AddType application/x-gzip .gz .tgz
添加對上述兩種文件的應用
#AddHandler cgi-script .cgi #修改為:AddHandler cgi-script .cgi .pl 表示允許擴展名為.pl的CGI腳本運行 AddType text/html .shtml AddOutputFilter INCLUDES .shtml
添加動態(tài)處理類型為server-parsed由服務器預先分析網(wǎng)頁內(nèi)的標記,將標記改為正確的HTML標識
#ErrorDocument 404 /missing.html #當服務器出現(xiàn)404錯誤的時候,返回missing.html頁面 Alias /error/ "/var/www/error/" #賦值別名 <IfModule mod_negotiation.c> <IfModule mod_include.c> <Directory "/var/www/error"> AllowOverride None Options IncludesNoExec AddOutputFilter Includes html AddHandler type-map var Order allow,deny Allow from all LanguagePriority en es de fr ForceLanguagePriority Prefer Fallback </Directory>
對/var/www/error網(wǎng)頁的權(quán)限及操作
BrowserMatch "Mozilla/2" nokeepalive
BrowserMatch "MSIE 4\.0b2;" nokeepalive downgrade-1.0 force-response-1.0
BrowserMatch "RealPlayer 4\.0" force-response-1.0
BrowserMatch "Java/1\.0" force-response-1.0
BrowserMatch "JDK/1\.0" force-response-1.0
.....
設置特殊的參數(shù),以保證對老版本瀏覽器的兼容,并支持新瀏覽器的特性
#NameVirtualHost *:80 #如果啟用虛擬主機的話,必須將前面的注釋去掉,而且,第二部分的內(nèi)容都可以出現(xiàn)在每個虛擬主機部分。 # VirtualHost example: #<VirtualHost *:80> # ServerAdmin webmaster@www.linuxidc.com # DocumentRoot /www/docs/www.linuxidc.com # ServerName www.linuxidc.com # ErrorLog logs/www.linuxidc.com-error_log # CustomLog logs/www.linuxidc.com-access_log common #</VirtualHost>
www.linuxidc.com替換為你的網(wǎng)址
二、Apache擴展的配置文件
$APACHE_HOME/conf/extra # apache擴展的配置文件 [root@extra]# ll total 56 -rw-r--r-- 1 root root 2859 Jan 10 01:49 httpd-autoindex.conf -rw-r--r-- 1 root root 1753 Jan 10 01:49 httpd-dav.conf -rw-r--r-- 1 root root 2344 Jan 10 01:49 httpd-default.conf -rw-r--r-- 1 root root 1103 Jan 10 01:49 httpd-info.conf -rw-r--r-- 1 root root 5078 Jan 10 01:49 httpd-languages.conf -rw-r--r-- 1 root root 932 Jan 10 01:49 httpd-manual.conf -rw-r--r-- 1 root root 3789 Jan 10 01:49 httpd-mpm.conf -rw-r--r-- 1 root root 2207 Jan 10 01:49 httpd-multilang-errordoc.conf -rw-r--r-- 1 root root 11185 Jan 10 01:49 httpd-ssl.conf -rw-r--r-- 1 root root 817 Jan 10 01:49 httpd-userdir.conf -rw-r--r-- 1 root root 1507 Jan 10 01:49 httpd-vhosts.conf # 虛擬主機配置文件
三、httpd-vhosts.conf虛擬主機配置文件注釋
[root@extra]# egrep -v "^.*#|^$" httpd-vhosts.conf |nl NameVirtualHost *:80 # 基于名稱的虛擬主機配置( *:80表示監(jiān)聽本機所有ip) <VirtualHost *:80> # 定義一個虛擬主機 ServerAdmin webmaster@dummy-host.example.com # 配置管理員郵箱 DocumentRoot "/application/apache../docs/dummy-host.example.com" # 程序的站點目錄 ServerName dummy-host.example.com # 域名服務,需要apache mode_alias模塊支持 ServerAlias www.dummy-host.example.com # 虛擬主機別名 ErrorLog "logs/dummy-host.example.com-error_log"# 錯誤的日志路徑 CustomLog "logs/dummy-host.example.com-access_log" common #訪問日志配置(生產(chǎn)環(huán)境我們用combined格式代替common格式) </VirtualHost> <VirtualHost *:80> ServerAdmin webmaster@dummy-host2.example.com DocumentRoot "/application/apache2.2.22/docs/dummy-host2.example.com" ServerName dummy-host2.example.com ErrorLog "logs/dummy-host2.example.com-error_log" CustomLog "logs/dummy-host2.example.com-access_log" common </VirtualHost>
四、Apache服務存放站點的目錄
$APACHE_HOME/apache/htdocs # 默認存放網(wǎng)頁的路徑,輸入IP 到此目錄 能夠見到it's wroks! 就是此目錄 [root@htdocs]# less index.html <html><body><h1>It works!</h1></body></html>
五、Apache服務目錄結(jié)構(gòu)說明
[root@htdocs]# ls ../ bin build cgi-bin conf error htdocs icons include lib logs man manual modules
bin啟動文件目錄說明
|-- bin # apache服務的命令目錄
| |-- ab # http服務性能測試工具
| |-- apachectl # apache啟動命令
| |-- apr-1-config
| |-- apu-1-config
| |-- apxs # http服務編譯和安裝擴展模塊使用工具,在DSO方式模塊編譯時用到
| |-- checkgid
| |-- dbmmanage
| |-- envvars
| |-- envvars-std
| |-- htcacheclean # 清理磁盤緩沖區(qū)的控制命令
| |-- htdbm
| |-- htdigest
| |-- htpasswd # 建立和更新基本認證文件
| |-- httpd # httpd為apache的控制命令程序
| |-- httxt2dbm
| |-- logresolve
| -- rotatelogs # apache自帶的日子輪詢命令(cronolog生產(chǎn)環(huán)境使用比較多)。
conf配置文件目錄
[root@htdocs]# ls ../conf/ extra httpd.conf magic mime.types original /application/apache/conf/ # apache配置所有的配置文件目錄 |-- extra # 額外的apache配置文件目錄 如:httpd-vhost.conf | |-- httpd-autoindex.conf | |-- httpd-dav.conf | |-- httpd-default.conf | |-- httpd-info.conf | |-- httpd-languages.conf | |-- httpd-manual.conf | |-- httpd-mpm.conf | |-- httpd-multilang-errordoc.conf | |-- httpd-ssl.conf | |-- httpd-userdir.conf | |-- httpd-vhosts.conf |-- httpd.conf # apache主配置文件 |-- magic |-- mime.types |-- original | |-- extra | | |-- httpd-autoindex.conf | | |-- httpd-dav.conf # dav支持配置 | | |-- httpd-default.conf # 這個文件里配置的是apache的相關服務參數(shù):超時時間、保持鏈接 | | |-- httpd-info.conf | | |-- httpd-languages.conf # 語言支持 | | |-- httpd-manual.conf | | |-- httpd-mpm.conf # 服務器池管理,也是優(yōu)化apache的一個配置文件(apache的模式以及配置鏈接數(shù),常用模式為worker模式和profork模式,默認porfork) | | |-- httpd-multilang-errordoc.conf | | |-- httpd-ssl.conf # 提供apache ssl支持配置文件 | | |-- httpd-userdir.conf | | |-- httpd-vhosts.conf # 虛擬機的配置文件 | |-- httpd.conf
站點存放目錄
[root@apache]# ls -l htdocs/ # 默認的首頁文件都放在此目錄當中。 total 4 -rw-r--r-- 1 root root 44 Nov 21 2004 index.html
日志存放目錄
[root@es apache]# tree logs logs # apache服務默認的日志路徑,包括錯誤日志和訪問日志 |-- access_log # apache服務訪問日志 tail -f命令可以查看網(wǎng)頁用戶訪問的信息 |-- cgisock.16406 |-- error_log # apache服務的錯誤日志。如:apache服務啟動故障 |-- httpd.pid # httpd的pid文件,http進程啟動后,會把所有進程的id號寫到此文件
模塊目錄
[root@apache]# ls -l manual/ # apache的模塊目錄 如php mencache total 2984 -rw-r--r-- 1 root root 543 May 6 2008 bind.html -rw-r--r-- 1 root root 11422 Jan 3 2012 bind.html.de
以上所述是小編給大家介紹的Apache服務的主要目錄和配置文件詳解,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對本站網(wǎng)站的支持!
版權(quán)聲明:本站文章來源標注為YINGSOO的內(nèi)容版權(quán)均為本站所有,歡迎引用、轉(zhuǎn)載,請保持原文完整并注明來源及原文鏈接。禁止復制或仿造本網(wǎng)站,禁止在非www.sddonglingsh.com所屬的服務器上建立鏡像,否則將依法追究法律責任。本站部分內(nèi)容來源于網(wǎng)友推薦、互聯(lián)網(wǎng)收集整理而來,僅供學習參考,不代表本站立場,如有內(nèi)容涉嫌侵權(quán),請聯(lián)系alex-e#qq.com處理。