uber-go/zap을 사용하여 로그 수준에 따라 stdout 및 stderr에 로그
소개
uber-go/zap 라이브러리는 강력한 로깅 기능을 제공합니다. 특정 요구 사항을 충족하려면 다양한 수준의 로그를 stdout 및 stderr와 같은 별도의 대상으로 보내는 것이 유리할 수 있습니다. 이 문서에서는 이러한 분리를 달성하여 심각도에 따라 적절한 장치에 로그가 기록되도록 하는 방법을 살펴봅니다.
사용자 정의 로깅 구성
uber에서 사용자 정의 로깅 동작을 지정하려면 -go/zap, zap.Config 구조체를 활용할 수 있습니다. OutputPaths 및 ErrorOutputPaths 필드를 수정하여 다양한 로그 수준에 대한 대상을 제어할 수 있습니다. 그러나 OutputPaths 또는 ErrorOutputPaths에 하나의 경로만 설정된 경우 모든 로그는 수준에 관계없이 해당 단일 대상에 기록됩니다.
해결책: Zapcore.NewTee
원하는 분리를 달성하기 위해 여러 코어를 결합하는 티 코어를 생성하는 zapcore.NewTee를 사용합니다. 각 코어는 특정 수준의 로그를 독립적으로 처리하고 이를 해당 대상으로 보낼 수 있습니다. 이 솔루션을 구현하는 방법은 다음과 같습니다.
<code class="go">import ( "go.uber.org/zap" "go.uber.org/zap/zapcore" "os" ) func main() { stdoutSyncer := zapcore.Lock(os.Stdout) stderrSyncer := zapcore.Lock(os.Stderr) infoCore := zapcore.NewCore( zapcore.NewJSONEncoder(zap.NewProductionEncoderConfig()), stdoutSyncer, zap.InfoLevel, ) errorCore := zapcore.NewCore( zapcore.NewJSONEncoder(zap.NewProductionEncoderConfig()), stderrSyncer, zap.ErrorLevel, ) core := zapcore.NewTee(infoCore, errorCore) logger := zap.New(core) logger.Info("info log") logger.Error("error log") }</code>
이 예에서는 두 개의 코어를 생성합니다. 하나는 정보 수준 로그(stdout에 기록)용이고 다른 하나는 오류 수준 로그(stderr에 기록)용입니다. zapcore.NewTee 기능은 이러한 코어를 결합하여 다양한 수준의 로그가 별도의 대상으로 전달될 수 있도록 합니다.
stdout 또는 stderr을 /dev/null로 리디렉션하면 각 로그 메시지가 실제로 다음에 기록되는지 추가로 확인할 수 있습니다. 레벨에 따라 올바른 장치를 선택하세요.
위 내용은 Uber Go Zap 라이브러리를 사용하여 다양한 수준의 로그를 stdout 및 stderr로 분리하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

Go는 이진 인코딩 및 디코딩을 위해 "인코딩/이진"패키지를 사용합니다. 1)이 패키지는 binary.wart.write 및 binary.Read 기능을 작성하고 읽기 데이터를 제공합니다. 2) 올바른 엔디언 (예 : Bigendian 또는 Littleendian)을 선택하는 데주의를 기울이십시오. 3) 데이터 정렬 및 오류 처리도 데이터의 정확성과 성능을 보장하는 핵심입니다.

"바이트"PackageOffersefficientFunctionSformanipulatingByteslices.1) audeBytes.joinforconcateNatingSlices, 2) bytes.bufferforIncrementalWriting, 3) bytes.indexorBytes.IndexByTeForsearching, 4) bytes.ReaderReadingInCunks, 및 5) thepliteTor

theencoding/binarypackageingofectiveficizatebinaryoperationsduetoitssupportforendiannessandefficientdatahandling.toenhanceperformance : 1) usebinary.nativeBinary.nativeBinary.nativeBinary.nativeEndianFornativeendiannesstoavoidByteswapping.2) BatchReadandWriteOperationStoredUtei/over

GO의 바이트 패키지는 주로 바이트 슬라이스를 효율적으로 처리하는 데 사용됩니다. 1) Bytes를 사용하여 Buffer는 불필요한 메모리 할당을 피하기 위해 스트링 스 플라이 싱을 효율적으로 수행 할 수 있습니다. 2) BYTES.Equal 함수는 바이트 슬라이스를 빠르게 비교하는 데 사용됩니다. 3) bytes.index, bytes.split 및 bytes.replaceall 함수를 사용하여 바이트 슬라이스를 검색하고 조작 할 수 있지만 성능 문제에주의를 기울여야합니다.

바이트 패키지는 바이트 슬라이스를 효율적으로 처리하기위한 다양한 기능을 제공합니다. 1) 바이트 시퀀스를 확인하려면 바이트를 사용하십시오. 2) 바이트 슬라이스를 분할하려면 BYTES.SPLIT를 사용하십시오. 3) 바이트 시퀀스 바이트를 교체하십시오. 4) Bytes.join을 사용하여 여러 바이트 슬라이스를 연결하십시오. 5) Bytes.Buffer를 사용하여 데이터를 작성하십시오. 6) 오류 처리 및 데이터 검증을 위해 결합 된 바이트.

GO의 인코딩/이진 패키지는 이진 데이터를 처리하기위한 도구입니다. 1) 소규모 엔디안 및 대규모 엔디 언 엔디 어 바이트 오더를 지원하며 네트워크 프로토콜 및 파일 형식에 사용할 수 있습니다. 2) 복잡한 구조의 인코딩 및 디코딩은 읽기 및 쓰기 기능을 통해 처리 될 수 있습니다. 3) BYTE 순서 및 데이터 유형의 일관성에주의를 기울이십시오. 특히 다른 시스템간에 데이터가 전송 될 때, 특히 데이터가 전송 될 때. 이 패키지는 이진 데이터의 효율적인 처리에 적합하지만 바이트 슬라이스 및 길이를 신중하게 관리해야합니다.

go'sstringspackageincludeSentialtionFunctionsLikeCeceCecections, trimspace, split, andreplaceall.1) contassefficiledychecksforsubstrings.2) trimspaceremoveswhitespacetaintegrity.3) spliteparsparssessucturedtextlikecsv


핫 AI 도구

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

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

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

Clothoff.io
AI 옷 제거제

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

인기 기사

뜨거운 도구

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

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

ZendStudio 13.5.1 맥
강력한 PHP 통합 개발 환경

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

에디트플러스 중국어 크랙 버전
작은 크기, 구문 강조, 코드 프롬프트 기능을 지원하지 않음