亚洲国产日韩欧美一区二区三区,精品亚洲国产成人av在线,国产99视频精品免视看7,99国产精品久久久久久久成人热,欧美日韩亚洲国产综合乱

annuaire recherche
首頁 版本說明 從1.3升級到2.0 編譯時配置的改變 運行時配置的改變 雜項變化 第三方模塊 從 2.0 升級到 2.2 編譯時配置的改變 運行時配置的改變 雜項變化 第三方模塊 Apache 2.1/2.2 版本的新特性 核心增強 模塊增強 程序增強 針對模塊開發(fā)者的變化 Apache 2.0 版本的新特性 核心的增強 模塊的增強 Apache許可證 參考手冊 編譯與安裝 針對心急者的概述 要求 下載 解壓 配置源代碼樹 編譯 安裝 配置 測試 升級 啟動 Apache是怎樣啟動的 啟動時發(fā)生錯誤 隨系統(tǒng)啟動時啟動 額外信息 停止與重新啟動 簡介 立即停止 優(yōu)雅重啟 立即重啟 優(yōu)雅停止 附錄:信號和競爭條件 運行時配置指令 主配置文件 配置文件的語法 模塊 指令的作用域 .htaccess文件 配置段 配置段(容器)的類型 文件系統(tǒng)和網(wǎng)絡(luò)空間 虛擬主機 代理 允許使用哪些指令? 配置段的合并 內(nèi)容緩沖 簡介 緩沖概述 安全方面的考慮 文件句柄緩沖 內(nèi)存緩沖 磁盤緩沖 服務(wù)器全局配置 服務(wù)器標(biāo)識 文件定位 限制資源的使用 日志文件 安全警告 錯誤日志 訪問日志 日志滾動 管道日志 虛擬主機 其他日志文件 從URL到文件系統(tǒng)的映射 相關(guān)模塊和指令 DocumentRoot DocumentRoot以外的文件 用戶目錄 URL重定向 反向代理 重寫引擎 File Not Found 安全方面的提示 保持不斷更新和升級 ServerRoot目錄的權(quán)限 服務(wù)器端包含 關(guān)于CGI 未指定為腳本的CGI 指定為腳本的CGI 其他動態(tài)內(nèi)容的來源 系統(tǒng)設(shè)置的保護(hù) 默認(rèn)配置下服務(wù)器文件的保護(hù) 觀察日志文件 動態(tài)共享對象(DSO) 實現(xiàn) 用法概要 背景知識 優(yōu)點和缺點 內(nèi)容協(xié)商 關(guān)于內(nèi)容協(xié)商 Apache中的內(nèi)容協(xié)商 協(xié)商的方法 打亂品質(zhì)值 透明內(nèi)容協(xié)商的擴展 超鏈和名稱轉(zhuǎn)換說明 緩沖說明 更多信息 自定義錯誤響應(yīng) 行為 配置 自定義錯誤響應(yīng)與重定向 地址和端口綁定 概述 針對IPv6的特殊考慮 怎樣與虛擬主機協(xié)同工作 多路處理模塊(MPM) 簡介 選擇一個MPM 默認(rèn)的MPM 環(huán)境變量 設(shè)置環(huán)境變量 使用環(huán)境變量 用于特殊目的的環(huán)境變量 示例 處理器的使用 什么是處理器? 例子 程序員注意事項 過濾器 Apache2中的過濾器 智能過慮 使用過濾器 CGI腳本的Suexec執(zhí)行 開始之前 suEXEC的安全模型 配置和安裝suEXEC 啟用和禁用suEXEC 使用suEXEC 調(diào)試suEXEC 謹(jǐn)防Jabberwock:警告和舉例 性能調(diào)整 硬件和操作系統(tǒng) 運行時的配置 編譯時的配置 附錄:蹤跡的詳細(xì)分析 URL重寫指南 mod_rewrite簡介 實踐方案 URL的規(guī)劃 內(nèi)容的處理 對訪問的限制 其他 虛擬主機文檔 總述 虛擬主機支持 配置指令 基于主機名的虛擬主機 基于域名的虛擬主機和基于IP的虛擬主機比較 使用基于域名的虛擬主機 與舊版瀏覽器的兼容性 基于IP地址的虛擬主機 系統(tǒng)需求 如何配置Apache 設(shè)置多個守護(hù)進(jìn)程 配置擁有多個虛擬主機的單一守護(hù)進(jìn)程 動態(tài)配置大量虛擬主機 動機 概述 簡單的動態(tài)虛擬主機 一個實際的個人主頁系統(tǒng) 在同一個服務(wù)器上架設(shè)多個主機的虛擬系統(tǒng) 更為有效的基于IP地址的虛擬主機 使用老版本的Apache 使用mod_rewrite實現(xiàn)簡單的動態(tài)虛擬主機 使用mod_rewrite的個人主頁系統(tǒng) 使用獨立的虛擬主機配置文件 虛擬主機的普通配置示例 在一個IP地址上運行多個基于域名的web站點 在多于一個IP的情況下使用基于域名的虛擬主機 在不同的IP的地址(比如一個內(nèi)部和一個外部地址)上提供相同的內(nèi)容 在不同的端口上運行不同的站點 建立基于IP的虛擬主機 混用基于端口和基于IP的虛擬主機 混用基于域名和基于IP的虛擬主機 將虛擬主機和代理模塊一起使用 使用默認(rèn)虛擬主機 將一個基于域名的虛擬主機移植為一個基于IP的虛擬主機 使用ServerPath指令 深入討論虛擬主機的匹配 解析配置文件 虛擬主機匹配 小技巧 文件描述符限制 關(guān)于DNS和Apache 一個簡單示例 拒絕服務(wù) "主服務(wù)器"地址 避免這些問題的小技巧 附錄:進(jìn)一步的提示 常見問題 概述 SSL/TLS 加密 概述 文檔 mod_ssl 緒論 密碼技術(shù) 證書 安全套接字層(SSL) 參考 兼容性 配置指令 環(huán)境變量 自定義日志功能 如何... 加密方案和強制性高等級安全 客戶認(rèn)證和訪問控制 常見問題解答 About The Module Installation Configuration Certificates The SSL Protocol mod_ssl Support 如何.../指南 概述 認(rèn)證 相關(guān)模塊和指令 簡介 先決條件 啟用認(rèn)證 允許多人訪問 可能存在的問題 其他認(rèn)證方法 更多信息 CGI動態(tài)頁面 簡介 配置Apache以允許CGI 編寫CGI程序 程序還是不能運行! 幕后是怎樣操作的? CGI模塊/庫 更多信息 服務(wù)器端包含 簡介 什么是SSI? 配置服務(wù)器以允許SSI 基本SSI指令 附加的例子 我還能設(shè)置其它什么? 執(zhí)行命令 高級SSI技術(shù) 總結(jié) .htaccess文件 .htaccess文件 工作原理和使用方法 (不)使用.htaccess文件的場合 指令的生效 認(rèn)證舉例 服務(wù)器端包含(SSI)舉例 CGI舉例 疑難解答 用戶網(wǎng)站目錄 用戶網(wǎng)站目錄 用UserDir設(shè)置文件路徑 限定哪些用戶可以使用此功能 啟用對每個用戶都有效的cgi目錄 允許用戶改變配置 對特定平臺的說明 概述 Microsoft Windows 其他平臺 在Microsoft Windows中使用Apache 對操作系統(tǒng)的要求 下載 Apache for Windows 安裝 Apache for Windows 配置 Apache for Windows 以服務(wù)方式運行 Apache for Windows 作為控制臺程序運行Apache 測試安裝 編譯Windows下的Apache 系統(tǒng)要求 命令行編譯 Developer Studio集成開發(fā)環(huán)境的工作區(qū)編譯 項目組件 在Novell NetWare平臺上使用Apache Requirements Downloading Apache for NetWare Installing Apache for NetWare Running Apache for NetWare Configuring Apache for NetWare Compiling Apache for NetWare 在HP-UX中運行Apache The Apache EBCDIC Port Overview of the Apache EBCDIC Port Design Goals Technical Solution Porting Notes Document Storage Notes Apache Modules' Status Third Party Modules' Status 服務(wù)器與支持程序 概述 httpd 語法 選項 ab 語法 選項 Bugs apachectl 語法 選項 apxs 語法 選項 舉例 configure 語法 選項 環(huán)境變量 dbmmanage 語法 選項 Bugs htcacheclean 語法 選項 返回值 htdbm 語法 選項 Bugs 返回值 舉例 安全方面的考慮 限制 htdigest 語法 選項 htpasswd 語法 選項 返回值 舉例 安全方面的考慮 限制 logresolve 語法 選項 rotatelogs 語法 選項 Portability suexec 語法 選項 其他程序 log_server_status split-logfile 雜項文檔 概述 相關(guān)標(biāo)準(zhǔn) HTTP推薦標(biāo)準(zhǔn) HTML推薦標(biāo)準(zhǔn) 認(rèn)證 語言/國家代碼 Apache 模塊 描述模塊的術(shù)語 說明 狀態(tài) 源代碼文件 模塊標(biāo)識符 兼容性 描述指令的術(shù)語 說明 語法 默認(rèn)值(Default) 作用域(Context) 覆蓋項(Override) 狀態(tài) 模塊(Module) 兼容性(Compatibility) Apache核心(Core)特性 AcceptFilter AcceptPathInfo AccessFileName AddDefaultCharset AddOutputFilterByType AllowEncodedSlashes AllowOverride AuthName AuthType CGIMapExtension ContentDigest DefaultType <Directory> <DirectoryMatch> DocumentRoot EnableMMAP EnableSendfile ErrorDocument ErrorLog FileETag <Files> <FilesMatch> ForceType HostnameLookups <IfDefine> <IfModule> Include KeepAlive KeepAliveTimeout <Limit> <LimitExcept> LimitInternalRecursion LimitRequestBody LimitRequestFields LimitRequestFieldSize LimitRequestLine LimitXMLRequestBody <Location> <LocationMatch> LogLevel MaxKeepAliveRequests NameVirtualHost Options Require RLimitCPU RLimitMEM RLimitNPROC Satisfy ScriptInterpreterSource ServerAdmin ServerAlias ServerName ServerPath ServerRoot ServerSignature ServerTokens SetHandler SetInputFilter SetOutputFilter TimeOut TraceEnable UseCanonicalName UseCanonicalPhysicalPort <VirtualHost> Apache MPM 公共指令 AcceptMutex CoreDumpDirectory EnableExceptionHook GracefulShutdownTimeout Group Listen ListenBackLog LockFile MaxClients MaxMemFree MaxRequestsPerChild MaxSpareThreads MinSpareThreads PidFile ReceiveBufferSize ScoreBoardFile SendBufferSize ServerLimit StartServers StartThreads ThreadLimit ThreadsPerChild ThreadStackSize User Apache MPM beos MaxRequestsPerThread CoreDumpDirectory Group Listen ListenBacklog MaxClients MaxMemFree MaxSpareThreads MinSpareThreads PidFile ReceiveBufferSize ScoreBoardFile SendBufferSize StartThreads User Apache MPM event AcceptMutex CoreDumpDirectory EnableExceptionHook Group Listen ListenBacklog LockFile MaxClients MaxMemFree MaxRequestsPerChild MaxSpareThreads MinSpareThreads PidFile ScoreBoardFile SendBufferSize ServerLimit StartServers ThreadLimit ThreadsPerChild ThreadStackSize User Apache MPM netware MaxThreads Listen ListenBacklog MaxMemFree MaxRequestsPerChild MaxSpareThreads MinSpareThreads ReceiveBufferSize SendBufferSize StartThreads ThreadStackSize Apache MPM os2 Group Listen ListenBacklog MaxRequestsPerChild MaxSpareThreads MinSpareThreads PidFile ReceiveBufferSize SendBufferSize StartServers User Apache MPM prefork 工作方式 MaxSpareServers MinSpareServers AcceptMutex CoreDumpDirectory EnableExceptionHook Group Listen ListenBacklog LockFile MaxClients MaxMemFree MaxRequestsPerChild PidFile ReceiveBufferSize ScoreBoardFile SendBufferSize ServerLimit StartServers User Apache MPM winnt Win32DisableAcceptEx CoreDumpDirectory Listen ListenBacklog MaxMemFree MaxRequestsPerChild PidFile ReceiveBufferSize ScoreBoardFile SendBufferSize ThreadLimit ThreadsPerChild ThreadStackSize Apache MPM worker 工作方式 AcceptMutex CoreDumpDirectory EnableExceptionHook Group Listen ListenBacklog LockFile MaxClients MaxMemFree MaxRequestsPerChild MaxSpareThreads MinSpareThreads PidFile ReceiveBufferSize ScoreBoardFile SendBufferSize ServerLimit StartServers ThreadLimit ThreadsPerChild ThreadStackSize User Apache Module mod_actions Action指令 Script指令 Apache Module mod_alias 處理順序 Alias AliasMatch Redirect RedirectMatch RedirectPermanent RedirectTemp ScriptAlias ScriptAliasMatch Apache Module mod_asis 用法 Apache Module mod_auth_basic AuthBasicAuthoritative AuthBasicProvider Apache Module mod_auth_digest 使用摘要認(rèn)證 配合 MS Internet Explorer 6 工作 AuthDigestAlgorithm AuthDigestDomain AuthDigestNcCheck AuthDigestNonceFormat AuthDigestNonceLifetime AuthDigestProvider AuthDigestQop AuthDigestShmemSize Apache Module mod_authn_alias 示例 <AuthnProviderAlias> Apache Module mod_authn_anon 示例 Anonymous Anonymous_LogEmail Anonymous_MustGiveEmail Anonymous_NoUserID Anonymous_VerifyEmail Apache Module mod_authn_dbd 配置示例 AuthDBDUserPWQuery AuthDBDUserRealmQuery Apache Module mod_authn_dbm AuthDBMType AuthDBMUserFile Apache Module mod_authn_default AuthDefaultAuthoritative Apache Module mod_authn_file AuthUserFile Apache Module mod_authnz_ldap Contents Operation The require Directives 舉例 Using TLS Using SSL Using Microsoft FrontPage with mod_authnz_ldap AuthLDAPBindDN AuthLDAPBindPassword AuthLDAPCharsetConfig AuthLDAPCompareDNOnServer AuthLDAPDereferenceAliases AuthLDAPGroupAttribute AuthLDAPGroupAttributeIsDN AuthLDAPRemoteUserIsDN AuthLDAPUrl AuthzLDAPAuthoritative Apache Module mod_authz_dbm AuthDBMGroupFile AuthzDBMAuthoritative AuthzDBMType Apache Module mod_authz_default AuthzDefaultAuthoritative Apache Module mod_authz_groupfile AuthGroupFile AuthzGroupFileAuthoritative Apache Module mod_authz_host Allow Deny Order Apache Module mod_authz_owner 配置示例 AuthzOwnerAuthoritative Apache Module mod_authz_user AuthzUserAuthoritative Apache Module mod_autoindex Autoindex Request Query Arguments AddAlt AddAltByEncoding AddAltByType AddDescription AddIcon AddIconByEncoding AddIconByType DefaultIcon HeaderName IndexIgnore IndexOptions IndexOrderDefault IndexStyleSheet ReadmeName Apache Module mod_cache Related Modules and Directives 配置示例 CacheDefaultExpire CacheDisable CacheEnable CacheIgnoreCacheControl CacheIgnoreHeaders CacheIgnoreNoLastMod CacheLastModifiedFactor CacheMaxExpire CacheStoreNoStore CacheStorePrivate Apache Module mod_cern_meta MetaDir MetaFiles MetaSuffix Apache Module mod_cgi CGI 環(huán)境變量 CGI 腳本的調(diào)試 ScriptLog ScriptLogBuffer ScriptLogLength Apache Module mod_cgid ScriptSock ScriptLog ScriptLogBuffer ScriptLogLength Apache Module mod_charset_lite Common Problems CharsetDefault CharsetOptions CharsetSourceEnc Apache Module mod_dav Enabling WebDAV Security Issues Complex Configurations Dav DavDepthInfinity DavMinTimeout Apache Module mod_dav_fs DavLockDB Apache Module mod_dav_lock DavGenericLockDB Apache Module mod_dbd Connection Pooling Apache DBD API SQL Prepared Statements DBDExptime DBDKeep DBDMax DBDMin DBDParams DBDPersist DBDPrepareSQL DBDriver Apache Module mod_deflate 配置舉例 啟用壓縮 代理服務(wù)器 DeflateBufferSize DeflateCompressionLevel DeflateFilterNote DeflateMemLevel DeflateWindowSize Apache Module mod_dir DirectoryIndex DirectorySlash Apache Module mod_disk_cache CacheDirLength CacheDirLevels CacheMaxFileSize CacheMinFileSize CacheRoot Apache Module mod_dumpio 啟用dumpio支持 DumpIOInput DumpIOOutput Apache Module mod_echo ProtocolEcho Apache Module mod_env PassEnv SetEnv UnsetEnv Apache Module mod_example Compiling the example module Using the mod_example Module Example Apache Module mod_expires 交替間隔語法 ExpiresActive ExpiresByType ExpiresDefault Apache Module mod_ext_filter 舉例 ExtFilterDefine ExtFilterOptions Apache Module mod_file_cache Using mod_file_cache CacheFile MMapFile Apache Module mod_filter Smart Filtering Filter Declarations Configuring the Chain Examples Protocol Handling FilterChain FilterDeclare FilterProtocol FilterProvider FilterTrace Apache Module mod_headers 處理順序 前處理和后處理 舉例 Header RequestHeader Apache Module mod_ident IdentityCheck IdentityCheckTimeout Apache Module mod_imagemap New Features Imagemap File Example Mapfile Referencing your mapfile ImapBase ImapDefault ImapMenu Apache Module mod_include Enabling Server-Side Includes PATH_INFO with Server Side Includes Basic Elements Include Variables Variable Substitution Flow Control Elements SSIEndTag SSIErrorMsg SSIStartTag SSITimeFormat SSIUndefinedEcho XBitHack Apache Module mod_info 安全問題 選擇哪些信息可以被顯示 已知的局限 AddModuleInfo Apache Module mod_isapi 用法 附加注釋 程序員注記 ISAPIAppendLogToErrors ISAPIAppendLogToQuery ISAPICacheFile ISAPIFakeAsync ISAPILogNotSupported ISAPIReadAheadBuffer Apache Module mod_ldap 示例配置 LDAP 連接池 LDAP 緩沖 使用SSL/TLS SSL/TLS 證書 LDAPCacheEntries LDAPCacheTTL LDAPConnectionTimeout LDAPOpCacheEntries LDAPOpCacheTTL LDAPSharedCacheFile LDAPSharedCacheSize LDAPTrustedClientCert LDAPTrustedGlobalCert LDAPTrustedMode LDAPVerifyServerCert Apache Module mod_log_config 定制日志文件格式 安全考慮 BufferedLogs CookieLog CustomLog LogFormat TransferLog Apache Module mod_log_forensic 定制日志文件格式 安全考慮 ForensicLog Apache Module mod_logio 定制日志文件格式 Apache Module mod_mem_cache MCacheMaxObjectCount MCacheMaxObjectSize MCacheMaxStreamingBuffer MCacheMinObjectSize MCacheRemovalAlgorithm MCacheSize Apache Module mod_mime 帶多擴展名的文件 內(nèi)容編碼 字符集和語言 AddCharset AddEncoding AddHandler AddInputFilter AddLanguage AddOutputFilter AddType DefaultLanguage ModMimeUsePathInfo MultiviewsMatch RemoveCharset RemoveEncoding RemoveHandler RemoveInputFilter RemoveLanguage RemoveOutputFilter RemoveType TypesConfig Apache Module mod_mime_magic "Magic文件"的格式 性能問題 注意 MimeMagicFile Apache Module mod_negotiation 類型表 MultiViews CacheNegotiatedDocs ForceLanguagePriority LanguagePriority Apache Module mod_nw_ssl NWSSLTrustedCerts NWSSLUpgradeable SecureListen Apache Module mod_proxy 正向和反向代理 簡單示例 控制對代理服務(wù)器的訪問 緩慢啟動 局域網(wǎng)代理 協(xié)議調(diào)整 請求體 AllowCONNECT NoProxy <Proxy> ProxyBadHeader ProxyBlock ProxyDomain ProxyErrorOverride ProxyIOBufferSize <ProxyMatch> ProxyMaxForwards ProxyPass ProxyPassReverse ProxyPassReverseCookieDomain ProxyPassReverseCookiePath ProxyPreserveHost ProxyReceiveBufferSize ProxyRemote ProxyRemoteMatch ProxyRequests ProxyTimeout ProxyVia Apache Module mod_proxy_ajp Overview of the protocol Basic Packet Structure Request Packet Structure Response Packet Structure Apache Module mod_proxy_balancer Load balancer scheduler algorithm Request Counting Algorithm Weighted Traffic Counting Algorithm Enabling Balancer Manager Support Apache Module mod_proxy_connect Apache Module mod_proxy_ftp 為什么xxx類型的文件不能從FTP下載? 如何強制文件xxx使用FTP的ASCII形式下載? 我如何使用FTP上傳? 我如何能訪問我自己home目錄以外的FTP文件? 我如何才能在瀏覽器的URL框中隱藏FTP的明文密碼? Apache Module mod_proxy_http Apache Module mod_rewrite 特殊字符的引用 環(huán)境變量 實用方案 RewriteBase RewriteCond RewriteEngine RewriteLock RewriteLog RewriteLogLevel RewriteMap RewriteOptions RewriteRule Apache Module mod_setenvif BrowserMatch BrowserMatchNoCase SetEnvIf SetEnvIfNoCase Apache Module mod_so 為Windows創(chuàng)建可加載模塊 LoadFile LoadModule Apache Module mod_speling CheckSpelling Apache Module mod_ssl 環(huán)境變量 Custom Log Formats SSLCACertificateFile SSLCACertificatePath SSLCADNRequestFile SSLCADNRequestPath SSLCARevocationFile SSLCARevocationPath SSLCertificateChainFile SSLCertificateFile SSLCertificateKeyFile SSLCipherSuite SSLCryptoDevice SSLEngine SSLHonorCipherOrder SSLMutex SSLOptions SSLPassPhraseDialog SSLProtocol SSLProxyCACertificateFile SSLProxyCACertificatePath SSLProxyCARevocationFile SSLProxyCARevocationPath SSLProxyCipherSuite SSLProxyEngine SSLProxyMachineCertificateFile SSLProxyMachineCertificatePath SSLProxyProtocol SSLProxyVerify SSLProxyVerifyDepth SSLRandomSeed SSLRequire SSLRequireSSL SSLSessionCache SSLSessionCacheTimeout SSLUserName SSLVerifyClient SSLVerifyDepth Apache Module mod_status Enabling Status Support 自動更新 Machine Readable Status File ExtendedStatus Apache Module mod_suexec SuexecUserGroup Apache Module mod_unique_id Theory Apache Module mod_userdir UserDir Apache Module mod_usertrack Logging 2-digit or 4-digit dates for cookies? CookieDomain CookieExpires CookieName CookieStyle CookieTracking Apache Module mod_version <IfVersion> Apache Module mod_vhost_alias 目錄名稱的轉(zhuǎn)換 示例 VirtualDocumentRoot VirtualDocumentRootIP VirtualScriptAlias VirtualScriptAliasIP 開發(fā)者文檔 Overview Topics External Resources Apache API notes Basic concepts How handlers work Resource allocation and resource pools Configuration Debugging Memory Allocation in APR Available debugging options Allowable Combinations Activating Debugging Options Documenting Apache 2.0 Apache 2.0 Hook Functions Creating a hook function Hooking the hook Converting Modules from Apache 1.3 to Apache 2.0 The easier changes ... The messier changes... Request Processing in Apache 2.0 The Request Processing Cycle The Request Parsing Phase The Security Phase The Preparation Phase The Handler Phase How Filters Work in Apache 2.0 Filter Types How are filters inserted? Asis Explanations 詞匯和索引 詞匯表 模塊索引 指令索引 指令速查 譯者聲明
personnages

日志文件

要有效地管理Web服務(wù)器,就有必要反饋服務(wù)器的活動、性能以及出現(xiàn)的問題。Apache HTTP服務(wù)器提供了非常全面而靈活的日志記錄功能。本文將闡述如何配置文件以及如何理解日志內(nèi)容。

安全警告

任何人只要對Apache存放日志文件的目錄具有寫權(quán)限,也就當(dāng)然地可以獲得啟動Apache的用戶(通常是root)的權(quán)限,絕對不要隨意給予任何人存放日志文件目錄的寫權(quán)限。細(xì)節(jié)請參見安全方面的提示。

另外,日志文件可能會包含未加轉(zhuǎn)換的來自用戶的信息,用戶就有機會惡意插入控制符,所以處理原始日志時應(yīng)該當(dāng)心這個問題。

錯誤日志(Error Log)

錯誤日志是最重要的日志文件,其文件名和位置取決于ErrorLog指令。Apache httpd將在這個文件中存放診斷信息和處理請求中出現(xiàn)的錯誤,由于這里經(jīng)常包含了出錯細(xì)節(jié)以及如何解決,如果服務(wù)器啟動或運行中有問題,首先就應(yīng)該查看這個錯誤日志。

錯誤日志通常被寫入一個文件(unix系統(tǒng)上一般是error_log ,Windows和OS/2上一般是error.log)。在unix系統(tǒng)中,錯誤日志還可能被重定向到syslog或通過管道操作傳遞給一個程序。

錯誤日志的格式相對靈活,并可以附加文字描述。某些信息會出現(xiàn)在絕大多數(shù)記錄中,一個典型的例子是:

[Wed Oct 11 14:32:52 2000] [error] [client 127.0.0.1] client denied by server configuration: /export/home/live/ap/htdocs/test

其中,第一項是錯誤發(fā)生的日期和時間;第二項是錯誤的嚴(yán)重性,LogLevel指令使只有高于指定嚴(yán)重性級別的錯誤才會被記錄;第三項是導(dǎo)致錯誤的IP地址;此后是信息本身,在此例中,服務(wù)器拒絕了這個客戶的訪問。服務(wù)器在記錄被訪問文件時,用的是文件系統(tǒng)路徑,而不是Web路徑。

錯誤日志中會包含類似上述例子的多種類型的信息。此外,CGI腳本中任何輸出到stderr的信息會作為調(diào)試信息原封不動地記錄到錯誤日志中。

用戶可以增加或刪除錯誤日志的項。但是對某些特殊請求,在訪問日志(access log)中也會有相應(yīng)的記錄,比如上述例子在訪問日志中也會有相應(yīng)的記錄,其狀態(tài)碼是403,因為訪問日志也可以定制,所以可以從訪問日志中得到錯誤事件的更多信息。

在測試中,對任何問題持續(xù)監(jiān)視錯誤日志是非常有用的。在unix系統(tǒng)中,可以這樣做:

tail -f error_log

訪問日志(Access Log)

訪問日志中會記錄服務(wù)器所處理的所有請求,其文件名和位置取決于CustomLog指令,LogFormat指令可以簡化日志的內(nèi)容。這里闡述如何配置服務(wù)器的訪問日志。

實施日志管理,首先當(dāng)然必須產(chǎn)生訪問日志,然后才能分析日志從而得到有用的統(tǒng)計信息。日志分析不是Web服務(wù)器的職責(zé),已超出本文的范疇,更多資料和有關(guān)分析工具的信息,可以查看Open Directory或Yahoo 。

不同版本的Apache httpd使用了不同的模塊和指令來控制對訪問的記錄,包括mod_log_referer, mod_log_agent和TransferLog指令。現(xiàn)在,CustomLog指令包含了舊版本中相關(guān)指令的所有功能。

訪問日志的格式是高度靈活的,使用很象C風(fēng)格的printf()函數(shù)的格式字符串。下面有幾個例子,完整的說明可以查看用于mod_log_config模塊的格式字符串。

通用日志格式(Common Log Format)

這是一個典型的記錄格式:

LogFormat "%h %l %u %t \"%r\" %>s %b" common
CustomLog logs/access_log common

它定義了一種特定的記錄格式字符串,并給它起了個別名common ,其中的"%"指示服務(wù)器用某種信息替換,其他字符則不作替換。引號(")必須加反斜杠轉(zhuǎn)義,以避免被解釋為字符串的結(jié)束。格式字符串還可以包含特殊的控制符,如換行符"\n" 、制表符"\t"。

CustomLog指令建立一個使用指定別名的新日志文件,除非其文件名是以斜杠開頭的絕對路徑,否則其路徑就是相對于ServerRoot的相對路徑。

上述配置是一種被稱為通用日志格式(CLF)的記錄格式,它被許多不同的Web服務(wù)器所采用,并被許多日志分析程序所識別,它產(chǎn)生的記錄形如:

127.0.0.1 - frank [10/Oct/2000:13:55:36 -0700] "GET /apache_pb.gif HTTP/1.0" 200 2326

記錄的各部分說明如下:

127.0.0.1 (%h)
這是發(fā)送請求到服務(wù)器的客戶的IP地址。如果HostnameLookups設(shè)為 On ,則服務(wù)器會嘗試解析這個IP地址的主機名并替換此處的IP地址,但并不推薦這樣做,因為它會顯著拖慢服務(wù)器,最好是用一個日志后續(xù)處理器來判斷主機名,比如logresolve 。如果客戶和服務(wù)器之間存在代理,那么記錄中的這個IP地址就是那個代理的IP地址,而不是客戶機的真實IP地址。
- (%l)
這是由客戶端identd進(jìn)程判斷的RFC1413身份(identity),輸出中的符號"-"表示此處的信息無效。除非在嚴(yán)格控制的內(nèi)部網(wǎng)絡(luò)中,此信息通常很不可靠,不應(yīng)該被使用。只有在將IdentityCheck指令設(shè)為 On 時,Apache才會試圖得到這項信息。
frank (%u)
這是HTTP認(rèn)證系統(tǒng)得到的訪問該網(wǎng)頁的客戶標(biāo)識(userid),環(huán)境變量REMOTE_USER會被設(shè)為該值并提供給CGI腳本。如果狀態(tài)碼是401,表示客戶未通過認(rèn)證,則此值沒有意義。如果網(wǎng)頁沒有設(shè)置密碼保護(hù),則此項將是"-"。
[10/Oct/2000:13:55:36 -0700] (%t)
這是服務(wù)器完成請求處理時的時間,其格式是:

[日/月/年:時:分:秒 時區(qū)]
日 = 2數(shù)字
月 = 3字母
年 = 4數(shù)字
時 = 2數(shù)字
分 = 2數(shù)字
秒 = 2數(shù)字
時區(qū) = (+|-)4數(shù)字

可以在格式字符串中使用 %{format}t 來改變時間的輸出形式,其中的format與C標(biāo)準(zhǔn)庫中的strftime()用法相同。
"GET /apache_pb.gif HTTP/1.0" (\"%r\")
引號中是客戶端發(fā)出的包含許多有用信息的請求行??梢钥闯?,該客戶的動作是GET ,請求的資源是/apache_pb.gif ,使用的協(xié)議是HTTP/1.0 。另外,還可以記錄其他信息,如:格式字符串"%m %U%q %H"會記錄動作、路徑、查詢字符串、協(xié)議,其輸出和"%r"一樣。
200 (%>s)
這是服務(wù)器返回給客戶端的狀態(tài)碼。這個信息非常有價值,因為它指示了請求的結(jié)果,或者是被成功響應(yīng)了(以2開頭),或者被重定向了(以3開頭),或者出錯了(以4開頭),或者產(chǎn)生了服務(wù)器端錯誤(以5開頭)。完整的狀態(tài)碼列表參見HTTP規(guī)范(RFC2616第10章)。
2326 (%b)
最后這項是返回給客戶端的不包括響應(yīng)頭的字節(jié)數(shù)。如果沒有信息返回,則此項應(yīng)該是"-",如果希望記錄為"0"的形式,就應(yīng)該用%B 。

組合日志格式(Combined Log Format)

另一種常用的記錄格式是組合日志格式,形式如下:

LogFormat "%h %l %u %t \"%r\" %>s %b \"%{Referer}i\" \"%{User-agent}i\"" combined
CustomLog log/access_log combined

這種格式與通用日志格式類似,但是多了兩個 %{header}i 項,其中的header可以是任何請求頭。這種格式的記錄形如:

127.0.0.1 - frank [10/Oct/2000:13:55:36 -0700] "GET /apache_pb.gif HTTP/1.0" 200 2326 "http://www.example.com/start.html" "Mozilla/4.08 [en] (Win98; I ;Nav)"

其中,多出來的項是:

"http://www.example.com/start.html" (\"%{Referer}i\")
"Referer"請求頭。此項指明了該請求是被從哪個網(wǎng)頁提交過來的,這個網(wǎng)頁應(yīng)該包含有/apache_pb.gif或者其連接。
"Mozilla/4.08 [en] (Win98; I ;Nav)" (\"%{User-agent}i\")
"User-Agent"請求頭。此項是客戶端提供的瀏覽器識別信息。

多文件訪問日志

可以簡單地在配置文件中用多個CustomLog指令來建立多文件訪問日志。如下例,既記錄基本的CLF信息,又記錄提交網(wǎng)頁和瀏覽器的信息,最后兩行CustomLog示范了如何模擬ReferLogAgentLog指令的效果。

LogFormat "%h %l %u %t \"%r\" %>s %b" common
CustomLog logs/access_log common
CustomLog logs/referer_log "%{Referer}i -> %U"
CustomLog logs/agent_log "%{User-agent}i"

此例也說明了,記錄格式可以直接由CustomLog指定,而并不一定要用LogFormat起一個別名。

條件日志

許多時候,根據(jù)與請求特征相關(guān)的環(huán)境變量來有選擇地記錄某些客戶端請求會帶來便利。首先,需要使用SetEnvIf指令來設(shè)置特定的環(huán)境變量以標(biāo)識符合某種特定條件的請求,然后用CustomLog指令的 env= 子句,根據(jù)這些環(huán)境變量來決定記錄或排除特定的請求。例如:

# 不記錄本機發(fā)出的請求
SetEnvIf Remote_Addr "127\.0\.0\.1" dontlog
# 不記錄對robots.txt文件的請求
SetEnvIf Request_URI "^/robots\.txt$" dontlog
# 記錄其他請求
CustomLog logs/access_log common env=!dontlog

再如,將使用英語的請求記錄到一個日志,而記錄非英語的請求到另一個日志:

SetEnvIf Accept-Language "en" english
CustomLog logs/english_log common env=english
CustomLog logs/non_english_log common env=!english

雖然上述已經(jīng)展示了條件日志記錄的強大和靈活,但這不是控制日志內(nèi)容的唯一手段,還可以用日志后繼處理程序來剔除你不關(guān)心的內(nèi)容,從而使日志更加有用。

日志滾動

即使一個并不繁忙的服務(wù)器,其日志文件的信息量也會很大,一般每10000個請求,訪問日志就會增加1MB或更多。這就有必要定期滾動日志文件。由于Apache會保持日志文件的打開,并持續(xù)寫入信息,因此服務(wù)器運行期間不能執(zhí)行滾動操作。移動或者刪除日志文件以后,必須重新啟動服務(wù)器才能讓它打開新的日志文件。

優(yōu)雅的(graceful)方法重新啟動,可以使服務(wù)器啟用新的日志文件,而不丟失原來尚未寫入的信息。為此,有必要等待一段時間,讓服務(wù)器完成正在處理的請求,并將記錄寫入到原來的日志文件。以下是一個典型的日志滾動和為節(jié)省存儲空間而壓縮舊日志的例子:

mv access_log access_log.old
mv error_log error_log.old
apachectl graceful
sleep 600
gzip access_log.old error_log.old

另一種執(zhí)行滾動的方法是使用下一節(jié)闡述的管道日志。

管道日志

Apache httpd可以通過管道將訪問記錄和出錯信息傳遞給另一個進(jìn)程,而不是寫入一個文件,由于無須對主服務(wù)器進(jìn)行編程,這個功能顯著地增強了日志的靈活性。只要用管道操作符"|"后面跟一個可執(zhí)行文件名,就可以使這個程序從標(biāo)準(zhǔn)輸入設(shè)備獲得事件記錄。Apache在啟動時,會同時啟動這個管道日志進(jìn)程,并且在運行過程中,如果這個進(jìn)程崩潰了,會重新啟動這個進(jìn)程(所以我們稱這個技術(shù)為"可靠管道日志")。

管道日志進(jìn)程由其父進(jìn)程Apache httpd產(chǎn)生,并繼承其權(quán)限,這意味著管道進(jìn)程通常是作為root運行的,所以保持這個程序簡單而安全極為重要。

管道日志的一種重要用途是,允許日志滾動而無須重新啟動服務(wù)器。為此,服務(wù)器提供了一個簡單的程序rotatelogs 。每24小時滾動一次日志的例子如下:

CustomLog "|/usr/local/apache/bin/rotatelogs /var/log/access_log 86400" common

注意:引號用于界定整個管道命令行。雖然這是針對訪問日志的,但是其用法對于其他日志也一樣。

在其他站點,有一個類似但更靈活的日志滾動程序叫cronolog 。

如果有較簡單的離線處理日志的方案,就不應(yīng)該使用條件日志和管道日志,即使它們非常強大。

虛擬主機

如果服務(wù)器配有若干虛擬主機,那么還有幾個控制日志文件的功能。首先,可以把日志指令放在<VirtualHost>段之外,讓它們與主服務(wù)器使用同一個訪問日志和錯誤日志來記錄所有的請求和錯誤,但是這樣就不能方便的獲得每個虛擬主機的信息了。

如果把CustomLogErrorLog指令放在<VirtualHost>段內(nèi),所有對這個虛擬主機的請求和錯誤信息會被記錄在其私有的日志文件中,那些沒有在<VirtualHost>段內(nèi)使用日志指令的虛擬主機將仍然和主服務(wù)器使用同一個日志。這種方法對虛擬主機較少的服務(wù)器很有用,但虛擬主機非常多時,就會帶來管理上的困難,還經(jīng)常會產(chǎn)生文件描述符短缺的問題。

對于訪問日志,有一個很好的折衷方案,在同一個訪問日志文件中記錄對所有主機的訪問,而每條記錄都注明虛擬主機的信息,日后再把記錄拆開存入不同的文件。例如:

LogFormat "%v %l %u %t \"%r\" %>s %b" comonvhost
CustomLog logs/access_log comonvhost

%v 用來附加虛擬主機的信息。有個split-logfile程序可以根據(jù)不同的虛擬主機信息對日志進(jìn)行拆分,并將結(jié)果存入不同的文件。

其他日志文件

記錄接收和發(fā)送的實際字節(jié)數(shù)

mod_logio增加了兩個額外的LogFormat字段(%I 和 %O)用于記錄接收和發(fā)送的實際字節(jié)數(shù)。

對比記錄(Forensic Logging)

mod_log_forensic提供了對客戶端請求的對比記錄,也就是在請求被處理之前和處理完成之后進(jìn)行兩次記錄,所以對比日志(forensic log)對于每個請求都包含兩條記錄。對比記錄器(forensic logger)十分嚴(yán)格,不可以進(jìn)行定制。它可以成為無價的調(diào)試和安全工具。

PID文件

在啟動時,Apache httpd將會在logs/httpd.pid文件中保存其父進(jìn)程httpd的進(jìn)程ID(process id[PID])。該文件名可以用PidFile指令改變。該PID可以被管理員利用來重新啟動或者終止服務(wù)器后臺守護(hù)進(jìn)程。在Windows中,可以使用命令行參數(shù) -k 。更多信息請參見停止和重新啟動。

腳本日志

為了方便調(diào)試,可以用ScriptLog指令來記錄CGI腳本的輸入和輸出。此功能應(yīng)該僅用于測試,而不應(yīng)該用于正常工作的服務(wù)器。更多資料請參見mod_cgi文檔。

重寫日志

在使用強大且靈活的mod_rewrite時,幾乎都有必要用RewriteLog來幫助調(diào)試。這個日志提供了重寫引擎如何轉(zhuǎn)換請求的詳細(xì)分解信息,其詳細(xì)程度取決于RewriteLogLevel指令。

Article précédent: Article suivant: