亚洲av成人无遮挡网站在线观看,少妇性bbb搡bbb爽爽爽,亚洲av日韩精品久久久久久,兔费看少妇性l交大片免费,无码少妇一区二区三区

  免費(fèi)注冊 查看新帖 |

Chinaunix

  平臺 論壇 博客 文庫
最近訪問板塊 發(fā)新帖
查看: 3138 | 回復(fù): 8
打印 上一主題 下一主題

[Web] 動(dòng)態(tài)虛擬主機(jī)根據(jù)域名分隔日志腳本 [復(fù)制鏈接]

論壇徽章:
1
IT運(yùn)維版塊每日發(fā)帖之星
日期:2015-08-04 06:20:00
跳轉(zhuǎn)到指定樓層
1 [收藏(0)] [報(bào)告]
發(fā)表于 2009-07-17 17:47 |只看該作者 |倒序?yàn)g覽
為大容量動(dòng)態(tài)虛擬主機(jī)解決日志按域名分隔問題自己寫了這個(gè)腳本

#!/bin/sh
#動(dòng)態(tài)虛擬主機(jī)按域名分割日志 20090717

logPath="/var/log/httpd"
logPostfixName="_access_log"

if [ "$1" != "" ]
then
    logPath=$1
fi
if [ "$2" != "" ]
then
    logPostfixName=$2
fi

while read line
do
    domain=$(echo $line|cut -d' ' -f1)
    logFile="${logPath}/${domain}${logPostfixName}"
    code=$(echo $line|cut -d' ' -f10)

    #如果不是404錯(cuò)誤 或者 目標(biāo)日志已經(jīng)存在
   if [ "$code" != "404" -o -s "$logFile" ]
     then
         echo $line|cut -d' ' -f2- >>$logFile
     fi
done


腳本保存到 /etc/httpd/vlog.sh
修改apache配置
UseCanonicalName Off
<VirtualHost *>
    VirtualDocumentRoot /home//%0/public_html
    LogFormat "%V %h %l %u %t \"%r\" %s %b" vcommon
   CustomLog "|/etc/httpd/vlog.sh /var/log/httpd _access_log" vcommon
</VirtualHost>

在CentoOS 5 apache2.2 上測試通過,
用Bash些的腳本擔(dān)心效率問題,各位如有更好的解決方法請留言,謝謝

[ 本帖最后由 信天翁 于 2009-7-18 22:43 編輯 ]

論壇徽章:
1
IT運(yùn)維版塊每日發(fā)帖之星
日期:2015-08-04 06:20:00
2 [報(bào)告]
發(fā)表于 2009-07-26 00:16 |只看該作者
研究了一下bash shell,對腳本做了一下優(yōu)化,使用bash內(nèi)置字符串函數(shù)替換外置命令,性能提高三倍

  1. #!/bin/sh

  2. #動(dòng)態(tài)虛擬主機(jī)按域名分割日志
  3. #20090726 by xiao

  4. logPath=${1:-/var/log/httpd}
  5. logPostfixName=${2:-_access_log}

  6. while read line
  7. do
  8.     domain=${line%% *} #完整域名,部分域名用domain=${line%%.*}  
  9.     logFile="${logPath}/${domain}${logPostfixName}"
  10.     code=${line% *}
  11.     code=${code##* }
  12.     lline=${line#* }

  13.     #如果不是404錯(cuò)誤 或者 目標(biāo)日志已經(jīng)存在
  14.     if [ "$code" != "404" ] || [ -s "$logFile" ]
  15.     then
  16.         echo $lline >> $logFile
  17.     fi
  18. done

復(fù)制代碼

論壇徽章:
0
3 [報(bào)告]
發(fā)表于 2009-07-27 12:11 |只看該作者
實(shí)時(shí)處理的性能是很低的,對于高負(fù)載的服務(wù)器性能影響比較大,我們一般是先記錄在一起,每天自動(dòng)切割后,對已經(jīng)切割保留好的日志再做分揀。

只用一條命令:

awk '{print $0>$1}' access_log

論壇徽章:
1
技術(shù)圖書徽章
日期:2013-12-05 23:25:45
4 [報(bào)告]
發(fā)表于 2009-07-27 14:15 |只看該作者
不錯(cuò)。

不過apache自己有split-logfile,或者可以用cronolog

論壇徽章:
0
5 [報(bào)告]
發(fā)表于 2009-07-27 16:04 |只看該作者
是啊~ 為何不單獨(dú)為每個(gè)虛擬主機(jī)配置自己的日志呢?

論壇徽章:
1
IT運(yùn)維版塊每日發(fā)帖之星
日期:2015-08-04 06:20:00
6 [報(bào)告]
發(fā)表于 2009-07-27 18:29 |只看該作者
原帖由 HonestQiao 于 2009-7-27 14:15 發(fā)表
不錯(cuò)。

不過apache自己有split-logfile,或者可以用cronolog


我用的CentOS 5.3 系統(tǒng)里沒有split-logfile,
另外cronolog只能按當(dāng)前日期處理日志,它不分析日志內(nèi)容

剛下了apache 2.2 的源碼包,make了一下找到了split-logfile,原來是個(gè)perl腳本,去掉注釋后代碼如下

  1. #!/usr/bin/perl
  2. %is_open = ();

  3. while ($log_line = <STDIN>) {
  4.     ($vhost) = split (/\s/, $log_line);
  5.     $vhost = lc ($vhost) or "access";
  6.     if ($vhost =~ m#[/\\]#) { $vhost = "access" }
  7.     if (! $is_open{$vhost}) {
  8.         open $vhost, ">>${vhost}.log"
  9.             or die ("Can't open ${vhost}.log");
  10.         $is_open{$vhost} = 1;
  11.     }
  12.     $log_line =~ s/^\S*\s+//;
  13.     printf $vhost "%s", $log_line;
  14. }
  15. exit 0;
復(fù)制代碼

基本和我的腳本類似,不知道我上面的bash腳本和這個(gè)perl腳本那個(gè)更快一些,于是做了一下測試
測試腳本test.sh

  1. #!/bin/sh
  2. s='xxx.yyy.ccc 192.168.200.21 - - [20/Jul/2009:13:55:50 +0800] "GET / HTTP/1.1" 200 51707'
  3. ii=0
  4. while [ "$ii" -lt 1000 ]
  5. do
  6.   echo $s|$1
  7.   ((ii++))
  8. done
復(fù)制代碼

將三個(gè)腳本放到同一目錄下

[root@test test]# time ./test.sh ./split-logfile

real    0m3.759s
user    0m1.489s
sys     0m2.293s

[root@test test]# time ./test.sh ./vlog.sh

real    0m2.515s
user    0m0.782s
sys     0m1.764s

竟然是bash腳本更快一些

論壇徽章:
1
IT運(yùn)維版塊每日發(fā)帖之星
日期:2015-08-04 06:20:00
7 [報(bào)告]
發(fā)表于 2009-07-27 18:31 |只看該作者
原帖由 gucuiwen 于 2009-7-27 12:11 發(fā)表
實(shí)時(shí)處理的性能是很低的,對于高負(fù)載的服務(wù)器性能影響比較大,我們一般是先記錄在一起,每天自動(dòng)切割后,對已經(jīng)切割保留好的日志再做分揀。

只用一條命令:

awk '{print $0>$1}' access_log

這樣日志會很大吧,高負(fù)載的服務(wù)器一天怕得產(chǎn)生十幾個(gè)G的日志,擔(dān)心集中處理的速度

論壇徽章:
1
IT運(yùn)維版塊每日發(fā)帖之星
日期:2015-08-04 06:20:00
8 [報(bào)告]
發(fā)表于 2009-07-27 18:33 |只看該作者
原帖由 一刀砍死 于 2009-7-27 16:04 發(fā)表
是啊~ 為何不單獨(dú)為每個(gè)虛擬主機(jī)配置自己的日志呢?


有數(shù)百上千個(gè)虛擬主機(jī),每個(gè)都寫配置文件多累啊

論壇徽章:
0
9 [報(bào)告]
發(fā)表于 2012-02-20 14:23 |只看該作者
我使用了 LogFormat "%V %h %l %u %t \"%r\" %>s %b \"%{Referer}i\" \"%{User-Agent}i\"" vcombined 這樣的格式,那腳本要怎么改一下呢?
您需要登錄后才可以回帖 登錄 | 注冊

本版積分規(guī)則 發(fā)表回復(fù)

  

北京盛拓優(yōu)訊信息技術(shù)有限公司. 版權(quán)所有 京ICP備16024965號-6 北京市公安局海淀分局網(wǎng)監(jiān)中心備案編號:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年舉報(bào)專區(qū)
中國互聯(lián)網(wǎng)協(xié)會會員  聯(lián)系我們:huangweiwei@itpub.net
感謝所有關(guān)心和支持過ChinaUnix的朋友們 轉(zhuǎn)載本站內(nèi)容請注明原作者名及出處

清除 Cookies - ChinaUnix - Archiver - WAP - TOP