소프트웨어 시스템 규모가 지속적으로 확장됨에 따라 로깅 메커니즘은 시스템 개발에서 점점 더 중요한 부분이 되었습니다. 소프트웨어 작동 중에 자세한 정보를 기록함으로써 개발자는 코드의 실행 상태를 더 잘 이해할 수 있습니다. 문제를 식별하고 해결합니다. 강력하고 효율적인 프로그래밍 언어인 Go 언어는 개발자를 지원하기 위한 뛰어난 로깅 라이브러리도 많이 제공합니다.
이 기사에서는 일반적으로 사용되는 여러 Go 언어 로깅 라이브러리를 소개하고 해당 라이브러리의 사용법과 특성을 간략하게 소개하여 로깅 작업에 도움이 되기를 바랍니다.
- 로그 패키지
Go 언어와 함께 제공되는 로그 패키지는 간단하지만 다음과 같은 장점을 갖춘 모든 기능을 갖춘 로그 라이브러리입니다.
- 기본 로그 인쇄 기능을 지원하고 Println, Printf 및 Print 기능을 제공합니다.
로그 출력의 접두사, 로그 정보 출력 위치 및 기타 옵션을 지정할 수 있습니다. - 로그 수준을 설정하여 출력 세부 사항을 제어할 수 있습니다.
-
로그 패키지에 포함된 함수를 호출하면 쉽게 로깅을 수행할 수 있습니다. 예:
1 | log.Println( "This is a log message." )
|
로그인 후 복사
출력 결과는
1 | 2021/11/11 12:34:56 This is a log message.
|
로그인 후 복사
와 유사합니다. 그 중 출력 정보 앞의 시간은 자동으로 생성되며 로그가 기록된 시간을 나타냅니다.
zap
zap은 Uber에서 개발한 고성능 로그 라이브러리입니다. 주요 기능은 다음과 같습니다.
매우 빠르고 높은 동시성 환경을 지원합니다. 로그 수준, 출력 형식 및 기타 옵션을 구성할 수 있습니다. ; 콘솔, 파일, 네트워크 등을 포함한 다양한 로그 출력 방법을 제공합니다. 로그 필드를 유연하게 사용자 정의하여 대량의 데이터를 쉽게 색인화하고 쿼리할 수 있습니다.
로그 패키지에 비해 zap 로그 라이브러리는 더 빠른 출력 속도, 더 강력한 사용자 정의 기능 및 더 풍부한 기능을 제공합니다. 다음은 로그를 출력하기 위해 zap을 사용하는 간단한 예입니다.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 | package main
import (
"go.uber.org/zap"
)
func main() {
logger, err := zap.NewProduction()
if err != nil {
panic(err)
}
defer logger.Sync()
logger.Info( "This is a log message." , zap.String( "key" , "value" ))
}
|
로그인 후 복사
이 예에서는 zap 로거가 생성되고 Info 함수를 사용하여 일부 정보가 로그에 추가됩니다. 두 번째 매개변수 zap.String("key", "value")는 key라는 필드를 지정하고 해당 값을 value로 설정합니다. 출력 결과는 다음과 유사합니다.
1 | { "level" : "info" , "ts" :1636634174.8175042, "caller" : "main.go:9" , "msg" : "This is a log message." , "key" : "value" }
|
로그인 후 복사
출력 로그 정보에는 로그 수준, 출력 타임스탬프, 프로그램 실행 컨텍스트와 같은 여러 정보 필드가 포함되어 있음을 알 수 있습니다.
lumberjack
lumberjack은 개발자가 로그 파일을 작성할 때 회전을 구현하고 파일 크기를 제한하는 데 도움이 되는 간단한 로그 회전 라이브러리입니다. 로그를 파일로 직접 출력하는 것과 비교할 때 Lumberjack을 사용하면 다음과 같은 여러 가지 이점을 얻을 수 있습니다.