mirror of
https://github.com/zeromicro/go-zero.git
synced 2026-06-22 01:41:55 +08:00
Co-authored-by: kevin <wanjunfeng@gmail.com> Co-authored-by: Copilot <223556219+Copilot@users.noreply.github.com>
8.5 KiB
8.5 KiB
logx
logx 설정
type LogConf struct {
ServiceName string `json:",optional"`
Mode string `json:",default=console,options=[console,file,volume]"`
Encoding string `json:",default=json,options=[json,plain]"`
TimeFormat string `json:",optional"`
Path string `json:",default=logs"`
Level string `json:",default=info,options=[info,error,severe]"`
Compress bool `json:",optional"`
KeepDays int `json:",optional"`
StackCooldownMillis int `json:",default=100"`
MaxBackups int `json:",default=0"`
MaxSize int `json:",default=0"`
Rotation string `json:",default=daily,options=[daily,size]"`
}
ServiceName: 서비스 이름을 설정합니다. 선택 사항입니다.volume모드에서는 이 이름이 로그 파일 생성에 사용됩니다.rest/zrpc서비스에서는 이름이rest또는zrpc의 이름으로 자동 설정됩니다.Mode: 로그 출력 모드입니다. 기본값은console입니다.console모드는 로그를stdout/stderr에 씁니다.file모드는Path로 지정한 파일에 로그를 씁니다.volume모드는 docker에서 사용하며, 마운트된 볼륨에 로그를 씁니다.
Encoding: 로그 인코딩 방식을 나타냅니다. 기본값은json입니다.json모드는 로그를 json 형식으로 씁니다.plain모드는 터미널 색상이 활성화된 일반 텍스트로 로그를 씁니다.
TimeFormat: 시간 형식을 사용자 지정합니다. 선택 사항입니다. 기본값은2006-01-02T15:04:05.000Z07:00입니다.Path: 로그 경로를 설정합니다. 기본값은logs입니다.Level: 로그를 필터링할 로깅 레벨입니다. 기본값은info입니다.info: 모든 로그가 기록됩니다.error:info로그가 억제됩니다.severe:info와error로그가 억제되고severe로그만 기록됩니다.
Compress: 로그 파일 압축 여부입니다.file모드에서만 동작합니다.KeepDays: 로그 파일을 보관할 일수입니다. 지정한 일수가 지나면 오래된 파일이 자동으로 삭제됩니다.console모드에는 영향을 주지 않습니다.StackCooldownMillis: 스택 트레이스를 다시 기록하기까지의 밀리초입니다. 스택 트레이스 로그 폭주를 방지하는 데 사용됩니다.MaxBackups: 보관할 백업 로그 파일 개수입니다. 0은 모든 파일을 영구 보관한다는 의미입니다.Rotation이size일 때만 적용됩니다. 참고:KeepDays옵션의 우선순위가 더 높습니다.MaxBackups가 0이더라도KeepDays제한에 도달하면 로그 파일은 삭제됩니다.MaxSize: 현재 기록 중인 로그 파일이 차지할 수 있는 최대 공간입니다. 0은 제한 없음을 의미합니다. 단위는MB입니다.Rotation이size일 때만 적용됩니다.Rotation: 로그 로테이션 규칙의 유형입니다. 기본값은daily입니다.daily: 날짜 단위로 로그를 회전합니다.size: 로그 크기 단위로 로그를 회전합니다.
로깅 메서드
type Logger interface {
// Error logs a message at error level.
Error(...any)
// Errorf logs a message at error level.
Errorf(string, ...any)
// Errorv logs a message at error level.
Errorv(any)
// Errorw logs a message at error level.
Errorw(string, ...LogField)
// Info logs a message at info level.
Info(...any)
// Infof logs a message at info level.
Infof(string, ...any)
// Infov logs a message at info level.
Infov(any)
// Infow logs a message at info level.
Infow(string, ...LogField)
// Slow logs a message at slow level.
Slow(...any)
// Slowf logs a message at slow level.
Slowf(string, ...any)
// Slowv logs a message at slow level.
Slowv(any)
// Sloww logs a message at slow level.
Sloww(string, ...LogField)
// WithContext returns a new logger with the given context.
WithContext(context.Context) Logger
// WithDuration returns a new logger with the given duration.
WithDuration(time.Duration) Logger
}
Error,Info,Slow:fmt.Sprint(…)처럼 모든 종류의 메시지를 로그에 씁니다.Errorf,Infof,Slowf: 지정한 형식으로 메시지를 로그에 씁니다.Errorv,Infov,Slowv: 모든 종류의 메시지를 json 마샬링으로 인코딩해 로그에 씁니다.Errorw,Infow,Sloww: 지정한key:value필드와 함께 문자열 메시지를 씁니다.WithContext: 지정한 ctx를 로그 메시지에 주입합니다. 일반적으로trace-id와span-id를 기록하는 데 사용됩니다.WithDuration: 경과 시간을duration키로 로그 메시지에 씁니다.
타사 로깅 라이브러리와 통합
- zap
- logrus
더 많은 라이브러리는 직접 구현한 뒤 https://github.com/zeromicro/zero-contrib에 PR을 보내주세요.
특정 저장소에 로그 쓰기
logx는 로그를 원하는 저장소에 쓸 수 있도록 사용자 지정할 수 있는 두 인터페이스를 정의합니다.
logx.NewWriter(w io.Writer)logx.SetWriter(writer logx.Writer)
예를 들어 로그를 콘솔이나 파일 대신 kafka에 쓰고 싶다면 아래처럼 할 수 있습니다.
type KafkaWriter struct {
Pusher *kq.Pusher
}
func NewKafkaWriter(pusher *kq.Pusher) *KafkaWriter {
return &KafkaWriter{
Pusher: pusher,
}
}
func (w *KafkaWriter) Write(p []byte) (n int, err error) {
// writing log with newlines, trim them.
if err := w.Pusher.Push(strings.TrimSpace(string(p))); err != nil {
return 0, err
}
return len(p), nil
}
func main() {
pusher := kq.NewPusher([]string{"localhost:9092"}, "go-zero")
defer pusher.Close()
writer := logx.NewWriter(NewKafkaWriter(pusher))
logx.SetWriter(writer)
// more code
}
전체 코드: https://github.com/zeromicro/zero-examples/blob/main/logx/tokafka/main.go
민감한 필드 필터링
password 필드가 로그에 기록되지 않도록 하려면 아래처럼 할 수 있습니다.
type (
Message struct {
Name string
Password string
Message string
}
SensitiveLogger struct {
logx.Writer
}
)
func NewSensitiveLogger(writer logx.Writer) *SensitiveLogger {
return &SensitiveLogger{
Writer: writer,
}
}
func (l *SensitiveLogger) Info(msg any, fields ...logx.LogField) {
if m, ok := msg.(Message); ok {
l.Writer.Info(Message{
Name: m.Name,
Password: "******",
Message: m.Message,
}, fields...)
} else {
l.Writer.Info(msg, fields...)
}
}
func main() {
// setup logx to make sure originalWriter not nil,
// the injected writer is only for filtering, like a middleware.
originalWriter := logx.Reset()
writer := NewSensitiveLogger(originalWriter)
logx.SetWriter(writer)
logx.Infov(Message{
Name: "foo",
Password: "shouldNotAppear",
Message: "bar",
})
// more code
}
전체 코드: https://github.com/zeromicro/zero-examples/blob/main/logx/filterfields/main.go
더 많은 예제
https://github.com/zeromicro/zero-examples/tree/main/logx
별을 눌러주세요! ⭐
이 프로젝트가 마음에 들거나 학습 또는 자체 솔루션을 시작하는 데 사용 중이라면 star를 눌러주세요. 감사합니다!