백엔드 개발 PHP 튜토리얼 순전히 수동으로 Nginx 로그를 가지고 플레이하세요.

순전히 수동으로 Nginx 로그를 가지고 플레이하세요.

Aug 08, 2016 am 09:22 AM
access buffer log quot request

Nginx 로그는 대부분의 사람들에게 알려지지 않은 보물입니다. 이전에 로그 분석 시스템을 구축한 경험을 요약하여 Nginx 로그의 순수한 수동 분석 방법을 공유하고 싶습니다. Nginx 로그 관련 구성에는 access_log와 log_format 두 곳이 있습니다. 기본 형식:
access_log <span>/</span>data<span>/</span>logs<span>/</span>nginx<span>-</span>access<span>.</span><span>log</span><span>;</span>log_format old <span><em>'$remote_addr [$time_local] $status $request_time $body_bytes_sent '</em></span><span><em>'"$request" "$http_referer" "$http_user_agent"'</em></span><span>;</span>
로그인 후 복사
Nginx를 사용해 본 대부분의 사람들은 기본 Nginx 로그 형식 구성과 로그 내용에 익숙할 것이라고 생각합니다. 그러나 기본 구성과 형식은 읽을 수는 있지만 계산하기는 어렵습니다. Nginx 로그 플러시 관련 전략을 구성할 수 있습니다. 예를 들어 버퍼가 가득 찬 경우에만 버퍼를 설정하고 디스크를 플러시합니다. 버퍼가 5초 미만인 경우 구성은 다음과 같습니다. 강제 플러시의 경우
access_log <span>/</span>data<span>/</span>logs<span>/</span>nginx<span>-</span>access<span>.</span><span>log</span> buffer<span>=</span><span><em>32k</em></span> flush<span>=</span><span><em>5s</em></span><span>;</span>
로그인 후 복사
로그를 실시간으로 볼 수 있는지 여부와 로그가 디스크 IO에 미치는 영향을 결정합니다. 기본 구성에는 나타나지 않지만 Nginx 로그에 기록할 수 있는 변수가 많이 있습니다. 예: 요청 데이터 크기: $request_length
반환 데이터 크기: $ bytes_sent
요청 시간: $request_time
사용된 연결 일련 번호: $connection
현재 연결에 대한 요청 수: $connection_requestsNginx의 기본 형식은 계산할 수 없습니다. 이를 계산 가능한 형식으로 변환하는 방법을 찾아야 합니다. 예를 들어 제어 문자 ^A(Mac에서는 Ctrl+V Ctrl+A 입력)를 사용하여 각 필드를 구분합니다. log_format의 형식은 다음과 같습니다.
log_format new <span><em>'$remote_addr^A$http_x_forwarded_for^A$host^A$time_local^A$status^A'</em></span><span><em>'$request_time^A$request_length^A$bytes_sent^A$http_referer^A$request^A$http_user_agent'</em></span><span>;</span>
로그인 후 복사
그 후 일반적인 Linux 명령줄 도구를 통해 분석할 수 있습니다.
  • 가장 찾기 자주 액세스하는 URL 및 시간:

    cat access.log | awk -F '^A' '{print $10}' | sort | uniq -c

  • 500 오류 액세스에 대한 현재 로그 파일을 찾습니다.

    cat access.log | awk -F '^A' '{if($5 == 500) print $0}'

  • 현재 로그 파일에서 500개 오류 수를 찾습니다.

    cat access.log | awk -F '^A' '{if($5 == 500) print $0}' | wc -l

  • 특정 분 수량 내에 500개의 잘못된 액세스 찾기 :

    cat access.log | awk -F '^A' '{if($5 == 500) print $0}' | grep '09:00' | wc-l

  • 소비량 찾기 1초를 초과하는 느린 요청:

    tail -f access.log | awk -F '^A' '{if($6>1) print $0}'

  • 특정 비트만 보려면 다음을 수행하세요.

    tail -f access.log | awk -F '^A' '{if($6>1) print $3″|”$4}'

  • 가장 많은 502개의 URL을 찾으세요. 오류:

    cat access.log | awk -F '^A' '{if($5==502) print $11}' | sort | uniq -c

  • 200개의 빈 페이지 찾기

    cat access.log | awk -F '^A' '{if($5==200 && $8 < 100) 인쇄 $3″|”$4″|”$11″|”$6}'

  • 실시간 로그 데이터 스트림 보기

    tail -f access.log | cat -e

    또는

    tail -f access.log | tr '^A' '|'

  • 요약이 아이디어를 기반으로 가장 많이 액세스한 UA, 요청 시간이 많이 소요되는 IP 분석, 등. 대규모 웹 로그 분석 시스템의 프로토타입입니다. 이 형식은 이후의 대규모 일괄 처리 및 스트리밍 계산에도 매우 편리합니다.

    위 내용은 다양한 측면을 포함하여 Nginx 로그를 수동으로 플레이하는 방법을 소개한 내용으로, PHP 튜토리얼에 관심이 있는 친구들에게 도움이 되기를 바랍니다.

    본 웹사이트의 성명
    본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

    핫 AI 도구

    Undresser.AI Undress

    Undresser.AI Undress

    사실적인 누드 사진을 만들기 위한 AI 기반 앱

    AI Clothes Remover

    AI Clothes Remover

    사진에서 옷을 제거하는 온라인 AI 도구입니다.

    Undress AI Tool

    Undress AI Tool

    무료로 이미지를 벗다

    Clothoff.io

    Clothoff.io

    AI 옷 제거제

    Video Face Swap

    Video Face Swap

    완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

    뜨거운 도구

    메모장++7.3.1

    메모장++7.3.1

    사용하기 쉬운 무료 코드 편집기

    SublimeText3 중국어 버전

    SublimeText3 중국어 버전

    중국어 버전, 사용하기 매우 쉽습니다.

    스튜디오 13.0.1 보내기

    스튜디오 13.0.1 보내기

    강력한 PHP 통합 개발 환경

    드림위버 CS6

    드림위버 CS6

    시각적 웹 개발 도구

    SublimeText3 Mac 버전

    SublimeText3 Mac 버전

    신 수준의 코드 편집 소프트웨어(SublimeText3)

    C#에서 멀티 스레딩의 이점은 무엇입니까? C#에서 멀티 스레딩의 이점은 무엇입니까? Apr 03, 2025 pm 02:51 PM

    멀티 스레딩의 장점은 특히 많은 양의 데이터를 처리하거나 시간이 많이 걸리는 작업을 수행하기 위해 성능 및 리소스 활용도를 향상시킬 수 있다는 것입니다. 이를 통해 여러 작업을 동시에 수행하여 효율성을 향상시킬 수 있습니다. 그러나 너무 많은 스레드가 성능 저하로 이어질 수 있으므로 CPU 코어 수와 작업 특성에 따라 스레드 수를 신중하게 선택해야합니다. 또한 다중 스레드 프로그래밍에는 교착 상태 및 레이스 조건과 같은 과제가 포함되며 동기화 메커니즘을 사용하여 해결해야하며 동시 프로그래밍에 대한 확실한 지식, 장단점을 측정하고주의해서 사용해야합니다.

    MySQL에 루트로 로그인 할 수 없습니다 MySQL에 루트로 로그인 할 수 없습니다 Apr 08, 2025 pm 04:54 PM

    Root로 MySQL에 로그인 할 수없는 주된 이유는 권한 문제, 구성 파일 오류, 암호 일관성이 없음, 소켓 파일 문제 또는 방화벽 차단입니다. 솔루션에는 다음이 포함됩니다. 구성 파일의 BAND-ADDRESS 매개 변수가 올바르게 구성되어 있는지 확인하십시오. 루트 사용자 권한이 수정 또는 삭제되어 재설정되었는지 확인하십시오. 케이스 및 특수 문자를 포함하여 비밀번호가 정확한지 확인하십시오. 소켓 파일 권한 설정 및 경로를 확인하십시오. 방화벽이 MySQL 서버에 연결되는지 확인하십시오.

    SQL IF 문을 사용하는 방법 SQL IF 문을 사용하는 방법 Apr 09, 2025 pm 06:12 PM

    SQL IF 명령문은 구문을 다음과 같이 조건부로 실행하는 데 사용됩니다. if (조건) 그런 다음 {state} else {state} end if;. 조건은 유효한 SQL 표현식 일 수 있으며 조건이 참이면 당시 조항을 실행하십시오. 조건이 false 인 경우 else 절을 ​​실행하십시오. 명세서를 중첩 할 수있는 경우 더 복잡한 조건부 점검이 가능합니다.

    노드 환경에서 403 오류를 반환하는 타사 인터페이스를 피하는 방법은 무엇입니까? 노드 환경에서 403 오류를 반환하는 타사 인터페이스를 피하는 방법은 무엇입니까? Apr 01, 2025 pm 02:03 PM

    노드 환경에서 403 오류를 반환하는 타사 인터페이스를 피하는 방법. node.js를 사용하여 타사 웹 사이트 인터페이스를 호출 할 때 때때로 403 오류를 반환하는 문제가 발생합니다. � ...

    도메인의 Vue Axios로 인한 '네트워크 오류'를 해결하는 방법 도메인의 Vue Axios로 인한 '네트워크 오류'를 해결하는 방법 Apr 07, 2025 pm 10:27 PM

    Vue Axios의 크로스 도메인 문제를 해결하는 방법 : Cors 플러그인을 사용하여 Websocket을 사용하여 JSONP를 사용하여 Axios 프록시를 사용하여 서버 측의 CORS 헤더 구성

    EasyWechat 5.5에서 component_verify_ticket을 효율적으로 얻는 방법은 무엇입니까? EasyWechat 5.5에서 component_verify_ticket을 효율적으로 얻는 방법은 무엇입니까? Apr 01, 2025 pm 12:42 PM

    EasyWechat5.5에서 구성 요소를 얻으십시오 ...

    웹 사이트 성과를 향상시키기 위해 Debian Apache Logs를 사용하는 방법 웹 사이트 성과를 향상시키기 위해 Debian Apache Logs를 사용하는 방법 Apr 12, 2025 pm 11:36 PM

    이 기사는 데비안 시스템에서 Apache Logs를 분석하여 웹 사이트 성능을 향상시키는 방법을 설명합니다. 1. 로그 분석 기본 사항 Apache Log는 IP 주소, 타임 스탬프, 요청 URL, HTTP 메소드 및 응답 코드를 포함한 모든 HTTP 요청의 자세한 정보를 기록합니다. 데비안 시스템 에서이 로그는 일반적으로 /var/log/apache2/access.log 및 /var/log/apache2/error.log 디렉토리에 있습니다. 로그 구조를 이해하는 것은 효과적인 분석의 첫 번째 단계입니다. 2. 로그 분석 도구 다양한 도구를 사용하여 Apache 로그를 분석 할 수 있습니다.

    Apache의 Zend를 구성하는 방법 Apache의 Zend를 구성하는 방법 Apr 13, 2025 pm 12:57 PM

    Apache에서 Zend를 구성하는 방법은 무엇입니까? Apache 웹 서버에서 Zend 프레임 워크를 구성하는 단계는 다음과 같습니다. Zend 프레임 워크를 설치하고 웹 서버 디렉토리로 추출하십시오. .htaccess 파일을 만듭니다. Zend 응용 프로그램 디렉토리를 작성하고 Index.php 파일을 추가하십시오. Zend 응용 프로그램 (application.ini)을 구성하십시오. Apache 웹 서버를 다시 시작하십시오.

    See all articles