1. 程式人生 > >十周四次課(3月5日)

十周四次課(3月5日)

linux

十周四次課(3月5日)
11.22 訪問日誌不記錄靜態文件

技術分享圖片


vim /usr/local/apache2.4/conf/extra/httpd-vhosts.conf

技術分享圖片

<VirtualHost :80>

DocumentRoot "/data/wwwroot/123.com"

ServerName 123.com
ServerAlias www.example.com 2111.com
SetEnvIf Request_URI ".*\.gif$" img
SetEnvIf Request_URI ".*\.jpg$" img
SetEnvIf Request_URI ".*\.png$" img

SetEnvIf Request_URI ".*\.bmp$" img
SetEnvIf Request_URI ".*\.swf$" img
SetEnvIf Request_URI ".*\.js$" img
SetEnvIf Request_URI ".*\.css$" img

CustomLog "logs/123.com-access_log" combined env=!img

</VirtualHost>

SetEnvIf這幾句的意思是定義一個環境變量,以標識請求URI中以gif,jpg,png等結尾的記錄,然後通過env=!img這一語句將這些排除掉,這樣日誌文件中就不會記錄這些占用存儲空間大卻又對於分析日誌幫助不大的靜態文件.

/usr/local/apache2.4/bin/apachectl -t
/usr/local/apache2.4/bin/apachectl graceful

測試

技術分享圖片

技術分享圖片

日誌

技術分享圖片

去掉字符再測試

技術分享圖片

技術分享圖片




11.23 訪問日誌切割

技術分享圖片


vim /usr/local/apache2.4/conf/extra/httpd-vhosts.conf

<VirtualHost :80>
DocumentRoot "/data/wwwroot/23.com"
ServerName 123.com
ServerAlias www.example.com 2111.com
SetEnvIf Request_URI ".*\.gif$" img

SetEnvIf Request_URI ".*\.jpg$" img
SetEnvIf Request_URI ".*\.png$" img
SetEnvIf Request_URI ".*\.bmp$" img
SetEnvIf Request_URI ".*\.swf$" img
SetEnvIf Request_URI ".*\.js$" img
SetEnvIf Request_URI ".*\.css$" img
CustomLog "|/usr/local/apache2.4/bin/rotatelogs -l logs/123.com-access_%Y%m%d.log 86400" combined env=!img

(CustomLog一行中,rotatelogs是apache自帶的日誌切割工具;-l參數是讓它以當前系統時間為基準來切割(比如在中國是CST,在美國是UTC,不指定則以UTC為基準);%Y%m%d變量則是讓切割的日誌文件名加上當前日期以便區分;86400是一天的秒數(24x60x60),表示以1天的頻率來進行切割.)

<VirtualHost :80>


/usr/local/apache2.4/bin/apachectl -t
/usr/local/apache2.4/bin/apachectl graceful


訪問日誌查看

技術分享圖片



11.24 靜態元素過期時間

技術分享圖片


  • vim /usr/local/apache2.4/conf/extra/httpd-vhosts.conf
    增加配置:
    <IfModule mod_expires.c>
    ExpiresActive on //打開該功能的開關
    ExpiresByType image/gif "access plus 1 days"
    ExpiresByType image/jpeg "access plus 24 hours"
    ExpiresByType image/png "access plus 24 hours"
    ExpiresByType text/css "now plus 2 hour"
    ExpiresByType application/x-javascript "now plus 2 hours"
    ExpiresByType application/javascript "now plus 2 hours"
    ExpiresByType application/x-shockwave-flash "now plus 2 hours"
    ExpiresDefault "now plus 0 min"
    </IfModule>

技術分享圖片


技術分享圖片

模塊未打開,編輯主配置文件,加載expires_module模塊

技術分享圖片

重新加載

/usr/local/apache2.4/bin/apachectl -t
/usr/local/apache2.4/bin/apachectl graceful


測試

技術分享圖片


技術分享圖片




擴展
apache日誌記錄代理IP以及真實客戶端IP 技術分享圖片http://ask.apelearn.com/question/960
apache只記錄指定URI的日誌 技術分享圖片http://ask.apelearn.com/question/981
apache日誌記錄客戶端請求的域名 技術分享圖片http://ask.apelearn.com/question/1037


十周四次課(3月5日)