Go에서 10초마다 대용량 로그 파일의 마지막 줄 읽기
대용량 로그 파일을 처리할 때는 효율적인 방법을 고안하는 것이 중요합니다. 메모리 과부하 없이 최신 데이터를 모니터링하고 분석합니다. 이 기사에서는 Go를 사용하여 10초마다 로그 파일의 마지막 두 줄을 읽는 접근 방식을 논의하여 이 문제를 해결합니다.
시작하려면 타이머 기능(time.Tick)을 활용합니다. 10초마다 트리거되도록 구성되었습니다. 이 함수 내에서 readFile 함수가 호출되어 로그 파일의 최신 줄을 요청합니다.
마지막 줄을 읽기 위한 시작점을 결정하기 위해 (os를 사용합니다. .File).Stat 메소드를 사용하여 파일 크기를 검색합니다. 각 줄이 약 32바이트에 걸쳐 있다고 가정하면 시작 위치는 fileSize - 62*(마지막 두 줄의 경우)로 계산됩니다.
다음은 가정에 따른 예입니다.
package main import ( "fmt" "os" "time" ) const MYFILE = "logfile.log" func main() { c := time.Tick(10 * time.Second) for now := range c { readFile(MYFILE) } } func readFile(fname string) { file, err := os.Open(fname) if err != nil { panic(err) } defer file.Close() buf := make([]byte, 62) stat, statErr := file.Stat() if statErr != nil { panic(statErr) } start := stat.Size() - 62 _, err = file.ReadAt(buf, start) if err == nil { fmt.Printf("%s\n", buf) } }
이 솔루션은 로그 파일을 메모리에 완전히 로드하지 않고 마지막 두 줄을 효율적으로 검색하여 대용량 로그 파일을 실시간으로 효율적으로 모니터링합니다.
위 내용은 Go에서 10초마다 대용량 로그 파일의 마지막 두 줄을 효율적으로 읽는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!