Nginx 로그 통계 분석 상용 명령

2944 단어
(인터넷 에서 베 낀 것, 기록 남기 기)
  • IP 방 문 량 통계 (독립 ip 방 문 량)
  • awk '{print $1}' access.log | sort -n | uniq | wc -l
    
  • 특정한 시간 대의 IP 방 문 량 보기 (4 - 5 시)
  • grep "07/Apr/2017:0[4-5]" access.log | awk '{print $1}' | sort | uniq -c| sort -nr | wc -l  
    
  • 가장 자주 방문 하 는 상위 100 개 IP 보기
  • awk '{print $1}' access.log | sort -n |uniq -c | sort -rn | head -n 100
    
  • 100 회 이상 방문 한 IP 보기
  • awk '{print $1}' access.log | sort -n |uniq -c |awk '{if($1 >100) print $0}'|sort -rn
    
  • 특정한 IP 의 상세 한 방문 상황 을 조회 하고 방문 빈도 에 따라 정렬
  • grep '127.0.01' access.log |awk '{print $7}'|sort |uniq -c |sort -rn |head -n 100
    
  • 가장 자주 방문 하 는 페이지 보기 (TOP 100)
  • awk '{print $7}' access.log | sort |uniq -c | sort -rn | head -n 100
    

    7. 가장 자주 방문 하 는 페이지 보기 ([php 페이지 제외] (TOP 100)
    grep -v ".php"  access.log | awk '{print $7}' | sort |uniq -c | sort -rn | head -n 100 
    
  • 페이지 방문 횟수 가 100 회 이상 인 페이지 보기
  • cat access.log | cut -d ' ' -f 7 | sort |uniq -c | awk '{if ($1 > 100) print $0}' | less
    
  • 최근 1000 개의 기록 을 살 펴 보고 가장 많이 방문 한 페이지
  • tail -1000 access.log |awk '{print $7}'|sort|uniq -c|sort -nr|less
    
  • 초당 요청 수 를 집계 하고 top 100 의 시간 (초 까지 정확)
  • awk '{print $4}' access.log |cut -c 14-21|sort|uniq -c|sort -nr|head -n 100'
    
  • 분당 요청 수 를 집계 하고 top 100 의 시간 (분 까지 정확)
  • awk '{print $4}' access.log |cut -c 14-18|sort|uniq -c|sort -nr|head -n 100
    

    12. 시간 당 요구 수, top 100 의 시간 점 (시간 까지 정확) 을 집계 한다.
    awk '{print $4}' access.log |cut -c 14-15|sort|uniq -c|sort -nr|head -n 100
    

    13. 성능 분석, nginx log 의 마지막 필드 에 $request time 추가
    전송 시간 이 3 초 이상 인 페이지 를 보 여 줍 니 다. 20 번 째 페이지 를 보 여 줍 니 다.
    cat access.log|awk '($NF > 3){print $7}'|sort -n|uniq -c|sort -nr|head -20
    

    php 페이지 요청 시간 이 3 초 이상 인 페이지 를 표시 하고 나타 난 횟수 를 집계 하여 100 개 를 표시 합 니 다.
    cat access.log|awk '($NF > 1 &&  $7~/\.php/){print $7}'|sort -n|uniq -c|sort -nr|head -100
    
  • 거미 잡기 횟수 통계
  • grep 'Baiduspider' access.log |wc -l
    
  • 거미 잡기 404 횟수 통계
  • grep 'Baiduspider' access.log |grep '404' | wc -l
    
  • TCP 연결 통계, 현재 TCP 연결 수 보기
  • netstat -tan | grep "ESTABLISHED" | grep ":80" | wc -l
    
  • tcpdump 로 80 포트 의 방문 을 탐지 하여 누가 가장 높 은 지
  • tcpdump -i eth0 -tnn dst port 80 -c 1000 | awk -F"." '{print $1"."$2"."$3"."$4}' | sort | uniq -c | sort -nr
    

    좋은 웹페이지 즐겨찾기