비즈니스 안정성 요구 사항이 상대적으로 높은 경우, 문제를 적시에 감지하기 위해 운영 및 유지 관리에서 특정 조건이 충족되면 수동적으로 기다리지 않고 즉시 애플리케이션 로그를 분석해야 하는 경우가 있습니다. 문제가 발생하려면 예를 들어 nginx의 $request_time 및 $upstream_response_time을 모니터링하고 가장 시간이 많이 걸리는 요청을 분석한 다음, 이때 로그인을 분석해야 합니다. 긴 문장을 발견하면 경고하고 알림을 보냅니다. 물론 이는 파일을 판단하거나 분석해야 하는 모든 곳에 적용할 수 있는 시나리오입니다. . 그래서 오늘은 Python을 사용하여 실시간으로 파일을 모니터링하는 방법을 살펴 보겠습니다.
첫 번째 방법:
이것은 Linux에 tail 명령이 있다는 것을 모두가 알고 있으므로 이해하기 가장 간단하고 쉽습니다. 따라서 Popen() 함수를 사용하여 이 명령을 직접 호출하여 출력을 얻을 수 있습니다.
logfile='access.log' command='tail -f ‘+logfile+'|grep “timeout”‘ popen=subprocess.Popen(command,stdout=subprocess.PIPE,stderr=subprocess.PIPE,shell=True) while True: line=popen.stdout.readline().strip() print line
두 번째 유형:
Python을 사용하여 파일을 조작합니다. 현재 파일 위치와 이동할 위치를 각각 얻기 위한 파일 객체입니다. 코드는 다음과 같습니다.
import time file = open(‘access.log') while 1: where = file.tell() line = file.readline() if not line: time.sleep(1) file.seek(where) else: print line,
세 번째 방법:
파이썬의 Yield를 사용하여 생성기 함수를 구현한 다음 이 생성기 함수를 호출하면 로그 파일이 변경될 때 새 줄이 인쇄되며 코드는 다음과 같습니다.
import time def follow(thefile): thefile.seek(0,2) while True: line = thefile.readline() if not line: time.sleep(0.1) continue yield line if __name__ == ‘__main__': logfile = open(“access-log”,”r”) loglines = follow(logfile) for line in loglines: print line,
마지막으로eek() 함수의 사용법을 설명합니다. 이 함수는 2개의 매개변수를 받습니다: file.seek(off, whence=0), 이동 오프 작업 표시(파일 포인터) ) 파일에서 양수는 끝 방향으로, 음수는 시작 방향으로 이동합니다. whence 매개변수가 설정된 경우, wherece에 의해 설정된 시작 위치가 우선합니다. 0은 시작을 나타내고, 1은 현재 위치를 나타내고, 2는 파일의 끝 위치를 나타냅니다.
위의 세 가지 일반적인 방법은 자신의 비즈니스 로직에 따라 특정 로그 분석 코드를 구현하면 됩니다.
위 내용은 이 글의 전체 내용입니다. 모든 분들의 학습에 도움이 되기를 바랍니다. 또한 모든 분들이 PHP 중국어 웹사이트를 구독하시기를 바랍니다.
파이썬의 실시간 파일 모니터링에 대한 더 많은 글은 PHP 중국어 홈페이지를 주목해주세요!

Arraysinpython, 특히 비밀 복구를위한 ArecrucialInscientificcomputing.1) theaRearedFornumericalOperations, DataAnalysis 및 MachinELearning.2) Numpy'SimplementationIncensuressuressurations thanpythonlists.3) arraysenablequick

Pyenv, Venv 및 Anaconda를 사용하여 다양한 Python 버전을 관리 할 수 있습니다. 1) PYENV를 사용하여 여러 Python 버전을 관리합니다. Pyenv를 설치하고 글로벌 및 로컬 버전을 설정하십시오. 2) VENV를 사용하여 프로젝트 종속성을 분리하기 위해 가상 환경을 만듭니다. 3) Anaconda를 사용하여 데이터 과학 프로젝트에서 Python 버전을 관리하십시오. 4) 시스템 수준의 작업을 위해 시스템 파이썬을 유지하십시오. 이러한 도구와 전략을 통해 다양한 버전의 Python을 효과적으로 관리하여 프로젝트의 원활한 실행을 보장 할 수 있습니다.

Numpyarrayshaveseveraladvantagesstandardpythonarrays : 1) thearemuchfasterduetoc 기반 간증, 2) thearemorememory-refficient, 특히 withlargedatasets 및 3) wepferoptizedformationsformationstaticaloperations, 만들기, 만들기

어레이의 균질성이 성능에 미치는 영향은 이중입니다. 1) 균질성은 컴파일러가 메모리 액세스를 최적화하고 성능을 향상시킬 수 있습니다. 2) 그러나 유형 다양성을 제한하여 비 효율성으로 이어질 수 있습니다. 요컨대, 올바른 데이터 구조를 선택하는 것이 중요합니다.

tocraftexecutablepythonscripts, 다음과 같은 비스트 프랙티스를 따르십시오 : 1) 1) addashebangline (#!/usr/bin/envpython3) tomakethescriptexecutable.2) setpermissionswithchmod xyour_script.py.3) organtionewithlarstringanduseifname == "__"

numpyarraysarebetterfornumericaloperations 및 multi-dimensionaldata, mumemer-efficientArrays

numpyarraysarebetterforheavynumericalcomputing, whilearraymoduleisiMoresuily-sportainedprojectswithsimpledatatypes.1) numpyarraysofferversatively 및 formanceforgedatasets 및 complexoperations.2) Thearraymoduleisweighit 및 ep

ctypesallowscreatingandmanipulatingC-stylearraysinPython.1)UsectypestointerfacewithClibrariesforperformance.2)CreateC-stylearraysfornumericalcomputations.3)PassarraystoCfunctionsforefficientoperations.However,becautiousofmemorymanagement,performanceo


핫 AI 도구

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

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

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

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

인기 기사

뜨거운 도구

Eclipse용 SAP NetWeaver 서버 어댑터
Eclipse를 SAP NetWeaver 애플리케이션 서버와 통합합니다.

DVWA
DVWA(Damn Vulnerable Web App)는 매우 취약한 PHP/MySQL 웹 애플리케이션입니다. 주요 목표는 보안 전문가가 법적 환경에서 자신의 기술과 도구를 테스트하고, 웹 개발자가 웹 응용 프로그램 보안 프로세스를 더 잘 이해할 수 있도록 돕고, 교사/학생이 교실 환경 웹 응용 프로그램에서 가르치고 배울 수 있도록 돕는 것입니다. 보안. DVWA의 목표는 다양한 난이도의 간단하고 간단한 인터페이스를 통해 가장 일반적인 웹 취약점 중 일부를 연습하는 것입니다. 이 소프트웨어는

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

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

VSCode Windows 64비트 다운로드
Microsoft에서 출시한 강력한 무료 IDE 편집기
