Subversion Repositories wimsdev

Rev

Rev 827 | Go to most recent revision | Blame | Compare with Previous | Last modification | View Log | RSS feed

  1. #! /bin/sh
  2. # logs and referer of documents, user and class connections in wims/log/...
  3. # Now must be called from wimslogd and housekeep.daily.
  4.  
  5. if [ "$site_accounting" != "yes" ]; then exit; fi
  6.  
  7. # working directory. Changeable.
  8. cd `dirname $0`/..
  9. wims_home=`pwd`
  10. tmpdir=$wims_home/tmp/log
  11. cd log
  12.  
  13. if [ -z "$1" ]; then workday=`date -d "22 hours ago" '+%Y%m%d'`; else workday=$1;fi
  14.  
  15. test=`grep $workday account/00access.act | awk '{print $1}'`
  16. if [ ! -z "$test" ]; then echo Accounting already done for $workday.; exit; fi
  17.  
  18. cat access.log* | grep $workday'\.' | grep -v 'devel/' | grep -v 'error' >$tmpdir/acctmp.log
  19.  
  20. cc=`grep -c . $tmpdir/acctmp.log`
  21. cd=`cat $tmpdir/acctmp.log | awk '{print $3}' | sort | uniq | grep -c .`
  22. cs=`cat session.log* | grep -c $workday`
  23. if [ $cd -gt 0 ]; then
  24.   avcc=`expr $cc / $cd`
  25.   avcs=`expr $cs / $cd`
  26. else
  27.   avcc=0
  28.   avcs=0
  29. fi
  30. echo "$workday  $cc     $cs     $cd     $avcc   $avcs" >>account/00access.act
  31.  
  32. ml=`cat $tmpdir/acctmp.log | awk 'length($5) < 39 {print $5}' | grep / | sort | uniq`
  33.  
  34. for i in $ml
  35. do
  36.  cc=`grep -c $i $tmpdir/acctmp.log`
  37.  cd=`grep $i $tmpdir/acctmp.log | awk '{print $3}' | sort | uniq | grep -c .`
  38.  j=`echo $i | tr '/' '@'`
  39.  if [ $cd -gt 0 ]; then
  40.    avcc=`expr $cc / $cd`
  41.  else
  42.    avcc=0
  43.  fi
  44.  echo "$workday $cc     $cd     $avcc" >>account/$j
  45. done
  46.  
  47. # Document accounting
  48. mkdir -p account/doc
  49. list=`cat modules/adm/doc.* |\
  50.  awk '/^'$workday'\./ && $4=="read" {print $5" "$3}' |\
  51.  grep -v '/' |\
  52.  awk '$1<100000 {print}' | sort -n`
  53. tot=`echo "$list" | awk '{print $1}' | sort -n | uniq`
  54. for d in $tot
  55. do
  56.  cc=`echo "$list" | grep -c '^'$d`
  57.  cd=`echo "$list" | grep '^'$d | awk '{print $2}' | sort | uniq | grep -c .`
  58.  if [ $cd -gt 0 ]; then
  59.   avcd=`expr $cc / $cd`
  60.  else
  61.   avcd=0
  62.  fi
  63.  echo "$workday $cc     $cd     $avcd" >>account/doc/$d
  64. done
  65. cc=`echo "$list" | grep -c .`
  66. cd=`echo "$list" | awk '{print $2}' | sort | uniq | grep -c .`
  67. if [ $cd -gt 0 ]; then
  68.   avcc=`expr $cc / $cd`
  69. else
  70.   avcc=0
  71. fi
  72. echo "$workday  $cc     $cd     $avcc" >>account/doc/0all
  73.  
  74. # clear unwanted module accounts
  75. rm -f account/home account/adm@* account/devel@* account/classes@* account/help@* account/light >/dev/null 2>&1
  76.  
  77. # exit
  78.  
  79. # Now referer logs.
  80.  
  81. cat /tmp/referer-home.log | sort | uniq | grep 'http://' | grep -v 'wims\.unice\.fr' | sed 's!http://!!g' | awk -F '#' '{print $1}' >>referer.log
  82. echo >/tmp/referer-home.log
  83.  
  84. cat referer.log* | grep $workday | awk '{print $3"              "$4}' \
  85.         | sort | uniq | sort -k 1 >$tmpdir/acctmp.log
  86.  
  87. grep -v '??' $tmpdir/acctmp.log >referer/refuniq.log
  88. a=`grep -c '??' $tmpdir/acctmp.log`
  89. echo "$workday  $a" >>referer/refauto.cnt
  90.  
  91. sed 's!?!/!g' referer/refuniq.log | awk -F/ '{print $1"/"$2}' > referer/refstem.log
  92. awk -F/ '{print $1}' referer/refstem.log >referer/refsite.log
  93.  
  94. for s in stem uniq site
  95. do
  96.  cat referer/ref$s.log | tr '\?' ' ' | awk '{print $2}' | uniq -c | sort -nr \
  97.         | awk '{print '$workday'" "$1"  "$2}' >> referer/ref$s.cnt
  98. done
  99.  
  100. rm -f $tmpdir/acctmp.log
  101.  
  102. month=`date -d $workday '+%m'`
  103. day=`date -d $workday '+%d'`
  104. year=`date -d $workday '+%Y'`
  105.  
  106. awk 'BEGIN {a=0.0};
  107.         substr($1,1,4)=="'$month$day'" {a=a+$3};
  108.         END {printf "'$year$month$day' %4d\n",int(a/0.288+0.5)};
  109.         ' load-$year$month >>account/00load.avg
  110.  
  111. # user and class connection time accounting
  112.  
  113. ccsum_outdir=ccaccount
  114. ccsum_date=$workday
  115.  
  116. rm -f $tmpdir/cc.log 2>/dev/null
  117. [ -f $ccsum_outdir/done ] && grep '^'$ccsum_date $ccsum_outdir/done >/dev/null && exit
  118.  
  119. cat access.log access.log.old* 2>/dev/null | grep '^'$ccsum_date'.*,' | sort >$tmpdir/cc.log
  120. if [ ! -s $tmpdir/cc.log ]; then exit; fi
  121.  
  122. export ccsum_outdir ccsum_date
  123. ../bin/ccsum $tmpdir/cc.log
  124. rm -f $tmpdir/cc.log
  125.  
  126.