COMING SOON 🚀

리눅스 쉘스크립트 배열을 이용해 webliazer 에서 다중 로그 분석

· 11년 전 · 2698

​웹호스팅 서비스하는 서버에서 여러 사이트 웹로그 분석할대 

webalizer 를 이용해서 분석하는데. 

.. 

여러 사이트를 쉘스크립트 배열 기능을 이용해서 

분석하게 해 봤습니다. 

.. 

리눅스 bash 에서 배열은 


ARRAY=("aa bb cc"  "dd ee ff" "gg hh ii") 


와 같이 선언하고 ${ARRAY[0]} 같이 참조합니다. 

그런데 아직 bash 에서 2차 배열 hash 는 안되는거 같습니다. 

아래와 같이 


for((  i=0;i<${#ARRAY[@]}; i++)) 

 do 

      TT=(${HTTPD_LOG_ARRAY[$i]}) 

      HTTPD_LOG_STAT=${TT[0]} 

      HTTPD_LOG_OUTPUT_DIR=${TT[1]} 

.. 

done 

처럼 for 안에서 다시 공백문자를 기준으로 

배열을 만들어서 

비슷하게 2차배열 처럼 사용할 수 있습니다. 

.. 

일단 이렇게 webalizer 로 분석하게 만든후 

각서버에 설정된 웹로그파일 백업하기 바로전에 이 스크립트가 

실행하게 해야 합니다. 

.. 

보통 리눅스 배포판에서는 /etc/cron.daily/logrotate 라는 스크립트 

상단에 적어주면 될겁니다. 

.. 

그리고 webalizer.conf 에서 

webalizer.current와 webalizer.hist 

부분을 주석처리 혹은 

파일 명만 할것 , 그래야 각 계정으로 들어가서 함. 

dnscache 부분도 0 으로 처리. 

.. 

php 를 쉘모드로 사용하는게 배열 다루기는 훨씬 쉽네요. 

.. 




============================================= 

  1 #!/bin/bash 

  2 

  3 declare -a HTTPD_LOG_ARRAY 

  4 

  5 # 분석할 로그파일, 로그파일 저장 디렉토리, 호스트이름 순으로 입력 

  6 HTTPD_LOG_ARRAY=( 

  7 "/var/log/httpd/aaa.com-access_log 

  8 /home/aaa/public_html/weblog 

  9 www.aaa.com

 10 

 11 "/var/log/httpd/bbb.com-access_log 

 12 /home/bbb/public_html/weblog 

 13 www.bbb.com

 14 

 15 "/var/log/httpd/ccc.com-access_log 

 16 /home/ccc/public_html/weblog 

 17 www.ccc.com

 18 

 19 )  

 20 

 21 

 22 for((  i=0;i<${#HTTPD_LOG_ARRAY[@]}; i++)) 

 23 do 

 24    TT=(${HTTPD_LOG_ARRAY[$i]}) 

 25    HTTPD_LOG_STAT=${TT[0]} 

 26    HTTPD_LOG_OUTPUT_DIR=${TT[1]} 

 27    HTTPD_LOG_HOSTNAME=${TT[2]} 

 28    # 아파치 로그를 읽어 hitcount 파일을 만든다. 

 29    if [ -f ${HTTPD_LOG_STAT} ]; then 

 30        if ! [ -d ${HTTPD_LOG_OUTPUT_DIR} ]; then 

 31            mkdir ${HTTPD_LOG_OUTPUT_DIR} 

 32        fi  

              cd ${HTTPD_LOG_OUTPUT_DIR} 

 33        /usr/bin/webalizer $HTTPD_LOG_STAT  -o $HTTPD_LOG_OUTPUT_DIR -n $HTTPD_LOG_HOSTNAME 

 34        

 35    fi  

 36    

 37 done 

|
댓글을 작성하시려면 로그인이 필요합니다.

프로그램

+
제목 글쓴이 날짜 조회
11년 전 조회 2,502
11년 전 조회 3,278
11년 전 조회 4,961
11년 전 조회 4,434
11년 전 조회 4,908
11년 전 조회 2,677
11년 전 조회 2,875
11년 전 조회 3,626
11년 전 조회 2,295
11년 전 조회 2,764
11년 전 조회 4,860
11년 전 조회 3,588
11년 전 조회 1,981
11년 전 조회 2,567
11년 전 조회 2,442
11년 전 조회 2,095
11년 전 조회 4,291
11년 전 조회 2,732
11년 전 조회 2,611
11년 전 조회 1,968
11년 전 조회 4,264
11년 전 조회 4,184
11년 전 조회 2,000
11년 전 조회 4,722
11년 전 조회 2,166
11년 전 조회 2,044
11년 전 조회 2,339
11년 전 조회 2,140
11년 전 조회 1,914
11년 전 조회 2,368
11년 전 조회 3,077
11년 전 조회 2,402
11년 전 조회 2,074
11년 전 조회 1,912
11년 전 조회 3,699
11년 전 조회 3,238
11년 전 조회 3,751
11년 전 조회 2,715
11년 전 조회 3,976
11년 전 조회 4,410
11년 전 조회 5,734
11년 전 조회 7,102
11년 전 조회 3,418
11년 전 조회 3,019
11년 전 조회 2,740
11년 전 조회 2,450
11년 전 조회 2,167
11년 전 조회 2,334
11년 전 조회 2,245
11년 전 조회 2,699
11년 전 조회 3,559
11년 전 조회 2,154
11년 전 조회 2,347
11년 전 조회 2,988
11년 전 조회 2,681
11년 전 조회 2,563
11년 전 조회 2,485
11년 전 조회 2,433
11년 전 조회 4,754
11년 전 조회 2,405
11년 전 조회 3,003
11년 전 조회 3,264
11년 전 조회 2,543
11년 전 조회 2,553
11년 전 조회 2,560
11년 전 조회 1,998
11년 전 조회 2,399
11년 전 조회 2,774
11년 전 조회 2,674
11년 전 조회 2,042
11년 전 조회 2,415
11년 전 조회 2,181
11년 전 조회 2,892
11년 전 조회 2,563
11년 전 조회 1,919
11년 전 조회 3,308
11년 전 조회 7,823
11년 전 조회 2,460
11년 전 조회 2,335
11년 전 조회 2,235
11년 전 조회 2,099
11년 전 조회 2,642
11년 전 조회 2,049
11년 전 조회 4,597
11년 전 조회 2,440
11년 전 조회 2,833
11년 전 조회 2,179
11년 전 조회 3,737
11년 전 조회 2,514
11년 전 조회 3,847
11년 전 조회 3,184
11년 전 조회 3,681
11년 전 조회 2,681
11년 전 조회 3,782
11년 전 조회 2,588
11년 전 조회 2,303
11년 전 조회 2,283
11년 전 조회 6,677
11년 전 조회 2,468
11년 전 조회 2,008