log/基于golangci-lint修改代码;

develop
Ge Song 2 years ago
parent 1cdffbd6ea
commit 25bea8ca37

@ -0,0 +1,141 @@
## 基于 golangci-lint@v1.52.2
run:
timeout: 1m
build-tags: [ ]
skip-dirs: [ ]
skip-files: [ ]
linters:
disable-all: true
enable:
- errcheck
- gosimple
- govet
- ineffassign
- staticcheck
- typecheck
- unused
- asasalint
- asciicheck
- bidichk
- bodyclose
- containedctx
- cyclop
- dupl
- durationcheck
- errname
- errorlint
- exhaustive
- exportloopref
- funlen
- gocheckcompilerdirectives
- gochecknoinits
- goconst
- gocritic
- gocyclo
- goimports
- gomnd
- goprintffuncname
- gosec
- lll
- loggercheck
- makezero
- nakedret
- nestif
- nilnil
- noctx
- nolintlint
- prealloc
- predeclared
- promlinter
- reassign
- revive
- rowserrcheck
- stylecheck
- tenv
- testableexamples
- testpackage
- tparallel
- unconvert
- unparam
- usestdlibvars
- wastedassign
- whitespace
linters-settings:
errcheck:
check-type-assertions: true
exclude-functions: [ ]
govet:
enable-all: true
disable: [ ]
cyclop:
max-complexity: 10
package-average: 0.0
dupl:
threshold: 150
exhaustive:
check:
- switch
- map
funlen:
lines: 100
statements: 60
gocritic:
disabled-checks:
- commentFormatting
settings:
captLocal:
paramsOnly: false
underef:
skipRecvDeref: false
gocyclo:
min-complexity: 20
gomnd:
ignored-functions:
- os.Chmod
- os.Mkdir
- os.MkdirAll
- os.OpenFile
- os.WriteFile
- prometheus.ExponentialBuckets
- prometheus.ExponentialBucketsRange
- prometheus.LinearBuckets
lll:
line-length: 240
nakedret:
max-func-lines: 10
nestif:
min-complexity: 5
predeclared:
ignore: ""
q: false
reassign:
patterns:
- ".*"
rowserrcheck:
packages:
- github.com/jmoiron/sqlx
tenv:
all: true
usestdlibvars:
time-month: true
time-layout: true
crypto-hash: true
default-rpc-path: true
os-dev-null: true
sql-isolation-level: true
tls-signature-scheme: true
constant-kind: true
syslog-priority: true
issues:
max-same-issues: 10
exclude-rules:
- source: "//noinspection"
linters: [ gocritic ]
- path: "_test\\.go"
linters:
- bodyclose
- dupl
- funlen
- goconst
- gosec
- noctx

@ -37,7 +37,7 @@ func (entry Entry) AddCallerSkip(n int) Entry {
// WithField 增加1组键值对 // WithField 增加1组键值对
func (entry Entry) WithField(key string, value any) Entry { func (entry Entry) WithField(key string, value any) Entry {
return entry.WithFields(KV{Key: key, Value: value}) return entry.WithFields(Field(key, value))
} }
// WithFields 增加键值对 // WithFields 增加键值对
@ -198,7 +198,7 @@ func (entry Entry) log(ctx context.Context, level Level, message string) {
readonlyEntry.Caller = getCaller(newEntry.callerSkip) readonlyEntry.Caller = getCaller(newEntry.callerSkip)
} }
if newEntry.GetReportStack() || level <= newEntry.logger.GetReportStackLevel() { if newEntry.GetReportStack() || level <= newEntry.logger.GetReportStackLevel() {
readonlyEntry.Stack = getStack(newEntry.callerSkip, 32) readonlyEntry.Stack = getStack(newEntry.callerSkip, maximumFrames)
} }
for _, processor := range newEntry.logger.getLevelProcessors(level) { for _, processor := range newEntry.logger.getLevelProcessors(level) {
processor.Process(ctx, readonlyEntry) processor.Process(ctx, readonlyEntry)

@ -3,13 +3,15 @@ package logsdk
// Field 返回键值对 // Field 返回键值对
func Field(key string, value any) KV { func Field(key string, value any) KV {
return KV{ return KV{
Value: value,
Key: key, Key: key,
Value: value,
} }
} }
// KV 是日志记录中的键值对 // KV 是日志记录中的键值对
//
//nolint:govet
type KV struct { type KV struct {
Value any `json:"v"`
Key string `json:"k"` Key string `json:"k"`
Value any `json:"v"`
} }

@ -28,6 +28,8 @@ func (level Level) MarshalText() ([]byte, error) {
return []byte(LevelDebugValue), nil return []byte(LevelDebugValue), nil
case LevelTrace: case LevelTrace:
return []byte(LevelTraceValue), nil return []byte(LevelTraceValue), nil
case LevelDisabled:
return []byte(levelDisabledValue), nil
} }
return nil, fmt.Errorf("not a valid log level %d", level) return nil, fmt.Errorf("not a valid log level %d", level)
} }
@ -61,6 +63,8 @@ const (
LevelInfoValue = "info" LevelInfoValue = "info"
LevelDebugValue = "debug" LevelDebugValue = "debug"
LevelTraceValue = "trace" LevelTraceValue = "trace"
levelDisabledValue = "disabled"
) )
var AllLevels = []Level{ var AllLevels = []Level{

@ -111,11 +111,12 @@ func (logger *Logger) Reset() {
// Exit 退出程序, 执行的具体过程可以通过 SetExit 指定 // Exit 退出程序, 执行的具体过程可以通过 SetExit 指定
func (logger *Logger) Exit(code int) { func (logger *Logger) Exit(code int) {
logger.lock.RLock() logger.lock.RLock()
defer logger.lock.RUnlock() exit := logger.exit
if logger.exit == nil { logger.lock.RUnlock()
if exit == nil {
os.Exit(code) os.Exit(code)
} }
logger.exit(code) exit(code)
} }
// SetExit 指定退出程序时执行的函数 // SetExit 指定退出程序时执行的函数
@ -134,7 +135,7 @@ func (logger *Logger) getLevelProcessors(level Level) []EntryProcessor {
func (logger *Logger) newEntry() Entry { func (logger *Logger) newEntry() Entry {
return Entry{ return Entry{
logger: logger, logger: logger,
callerSkip: logger.GetCallerSkip() + 2, callerSkip: logger.GetCallerSkip() + entrySkipOffset,
reportCaller: logger.GetReportCaller(), reportCaller: logger.GetReportCaller(),
reportStack: logger.GetReportStack(), reportStack: logger.GetReportStack(),
initialized: true, initialized: true,

@ -60,7 +60,7 @@ func newConfig(opts ...Option) *config {
opt.apply(cfg) opt.apply(cfg)
} }
if !cfg.hasPool { if !cfg.hasPool {
cfg.bytesBufferPool = NewBytesBufferPool(512, 4096) cfg.bytesBufferPool = NewBytesBufferPool(bytesBufferInitialSize, bytesBufferMaximumSize)
} }
if cfg.output == nil { if cfg.output == nil {
cfg.output = NewSyncWriter(os.Stderr) cfg.output = NewSyncWriter(os.Stderr)

@ -5,6 +5,11 @@ import (
"sync" "sync"
) )
const (
bytesBufferInitialSize = 512
bytesBufferMaximumSize = 4096
)
type BytesBufferPool interface { type BytesBufferPool interface {
Get() *bytes.Buffer Get() *bytes.Buffer
Put(buffer *bytes.Buffer) Put(buffer *bytes.Buffer)

@ -18,7 +18,7 @@ type syncWriter struct {
lock sync.Mutex lock sync.Mutex
} }
func (w *syncWriter) Write(p []byte) (n int, err error) { func (w *syncWriter) Write(p []byte) (int, error) {
w.lock.Lock() w.lock.Lock()
defer w.lock.Unlock() defer w.lock.Unlock()
return w.writer.Write(p) return w.writer.Write(p)

@ -4,6 +4,12 @@ import (
"runtime" "runtime"
) )
const (
maximumFrames = 32
getCallerSkipOffset = 2
entrySkipOffset = 2
)
// Frame 调用相关信息 // Frame 调用相关信息
type Frame struct { type Frame struct {
Function string `json:"func"` Function string `json:"func"`
@ -18,7 +24,7 @@ func (frame Frame) IsValid() bool {
func getCaller(skip int) Frame { func getCaller(skip int) Frame {
pc := make([]uintptr, 1) pc := make([]uintptr, 1)
n := runtime.Callers(skip+2, pc) n := runtime.Callers(skip+getCallerSkipOffset, pc)
frame, _ := runtime.CallersFrames(pc[:n]).Next() frame, _ := runtime.CallersFrames(pc[:n]).Next()
if frame.PC == 0 { if frame.PC == 0 {
return Frame{} return Frame{}
@ -32,7 +38,7 @@ func getCaller(skip int) Frame {
func getStack(skip, maximumFrames int) []Frame { func getStack(skip, maximumFrames int) []Frame {
pc := make([]uintptr, maximumFrames) pc := make([]uintptr, maximumFrames)
n := runtime.Callers(skip+2, pc) n := runtime.Callers(skip+getCallerSkipOffset, pc)
stack := make([]Frame, 0, n) stack := make([]Frame, 0, n)
frames := runtime.CallersFrames(pc[:n]) frames := runtime.CallersFrames(pc[:n])
for { for {

Loading…
Cancel
Save