MCPcopy
hub / github.com/uber-go/zap

github.com/uber-go/zap @v1.28.0 sqlite

repository ↗ · DeepWiki ↗ · release v1.28.0 ↗
1,375 symbols 6,335 edges 143 files 523 documented · 38%
README

:zap: zap

Blazing fast, structured, leveled logging in Go.

Zap logo

GoDoc Build Status Coverage Status

Installation

go get -u go.uber.org/zap

Note that zap only supports the two most recent minor versions of Go.

Quick Start

In contexts where performance is nice, but not critical, use the SugaredLogger. It's 4-10x faster than other structured logging packages and includes both structured and printf-style APIs.

logger, _ := zap.NewProduction()
defer logger.Sync() // flushes buffer, if any
sugar := logger.Sugar()
sugar.Infow("failed to fetch URL",
  // Structured context as loosely typed key-value pairs.
  "url", url,
  "attempt", 3,
  "backoff", time.Second,
)
sugar.Infof("Failed to fetch URL: %s", url)

When performance and type safety are critical, use the Logger. It's even faster than the SugaredLogger and allocates far less, but it only supports structured logging.

logger, _ := zap.NewProduction()
defer logger.Sync()
logger.Info("failed to fetch URL",
  // Structured context as strongly typed Field values.
  zap.String("url", url),
  zap.Int("attempt", 3),
  zap.Duration("backoff", time.Second),
)

See the documentation and FAQ for more details.

Performance

For applications that log in the hot path, reflection-based serialization and string formatting are prohibitively expensive — they're CPU-intensive and make many small allocations. Put differently, using encoding/json and fmt.Fprintf to log tons of interface{}s makes your application slow.

Zap takes a different approach. It includes a reflection-free, zero-allocation JSON encoder, and the base Logger strives to avoid serialization overhead and allocations wherever possible. By building the high-level SugaredLogger on that foundation, zap lets users choose when they need to count every allocation and when they'd prefer a more familiar, loosely typed API.

As measured by its own benchmarking suite, not only is zap more performant than comparable structured logging packages — it's also faster than the standard library. Like all benchmarks, take these with a grain of salt.1

Log a message and 10 fields:

Package Time Time % to zap Objects Allocated
:zap: zap 656 ns/op +0% 5 allocs/op
:zap: zap (sugared) 935 ns/op +43% 10 allocs/op
zerolog 380 ns/op -42% 1 allocs/op
go-kit 2249 ns/op +243% 57 allocs/op
slog (LogAttrs) 2479 ns/op +278% 40 allocs/op
slog 2481 ns/op +278% 42 allocs/op
apex/log 9591 ns/op +1362% 63 allocs/op
log15 11393 ns/op +1637% 75 allocs/op
logrus 11654 ns/op +1677% 79 allocs/op

Log a message with a logger that already has 10 fields of context:

Package Time Time % to zap Objects Allocated
:zap: zap 67 ns/op +0% 0 allocs/op
:zap: zap (sugared) 84 ns/op +25% 1 allocs/op
zerolog 35 ns/op -48% 0 allocs/op
slog 193 ns/op +188% 0 allocs/op
slog (LogAttrs) 200 ns/op +199% 0 allocs/op
go-kit 2460 ns/op +3572% 56 allocs/op
log15 9038 ns/op +13390% 70 allocs/op
apex/log 9068 ns/op +13434% 53 allocs/op
logrus 10521 ns/op +15603% 68 allocs/op

Log a static string, without any context or printf-style templating:

Package Time Time % to zap Objects Allocated
:zap: zap 63 ns/op +0% 0 allocs/op
:zap: zap (sugared) 81 ns/op +29% 1 allocs/op
zerolog 32 ns/op -49% 0 allocs/op
standard library 124 ns/op +97% 1 allocs/op
slog 196 ns/op +211% 0 allocs/op
slog (LogAttrs) 200 ns/op +217% 0 allocs/op
go-kit 213 ns/op +238% 9 allocs/op
apex/log 771 ns/op +1124% 5 allocs/op
logrus 1439 ns/op +2184% 23 allocs/op
log15 2069 ns/op +3184% 20 allocs/op

Development Status: Stable

All APIs are finalized, and no breaking changes will be made in the 1.x series of releases. Users of semver-aware dependency management systems should pin zap to ^1.

Contributing

We encourage and support an active, healthy community of contributors — including you! Details are in the contribution guide and the code of conduct. The zap maintainers keep an eye on issues and pull requests, but you can also report any negative conduct to oss-conduct@uber.com. That email list is a private, safe space; even the zap maintainers don't have access, so don't hesitate to hold us to a high standard.


Released under the MIT License.

1 In particular, keep in mind that we may be benchmarking against slightly older versions of other packages. Versions are pinned in the benchmarks/go.mod file.

Extension points exported contracts — how you extend this code

WriteSyncer (Interface)
A WriteSyncer is an io.Writer that can also flush any buffered data. Note that *os.File (and thus, os.Stderr and os.Stdo [17 …
zapcore/write_syncer.go
ObjectMarshaler (Interface)
ObjectMarshaler allows user-defined types to efficiently add themselves to the logging context, and to selectively omit [12 …
zapcore/marshaler.go
Core (Interface)
Core is a minimal, fast logger interface. It's designed for library authors to wrap in a more user-friendly API. [8 implementers]
zapcore/core.go
LevelEnabler (Interface)
LevelEnabler decides whether a given logging level is enabled when logging a message. Enablers are intended to be used [9 …
zapcore/level.go
LeveledEnabler (Interface)
LeveledEnabler is an interface satisfied by LevelEnablers that are able to report their own level. This interface is de [9 …
internal/level_enabler.go
ObjectEncoder (Interface)
ObjectEncoder is a strongly-typed, encoding-agnostic interface for adding a map- or struct-like object to the logging co [2 …
zapcore/encoder.go
CheckWriteHook (Interface)
CheckWriteHook is a custom action that may be executed after an entry is written. Register one on a CheckedEntry with t [2 …
zapcore/entry.go
Clock (Interface)
Clock is a source of time for logged entries. [2 implementers]
zapcore/clock.go

Core symbols most depended-on inside this repo

Info
called by 145
logger.go
Any
called by 109
field.go
Int
called by 89
field.go
Next
called by 87
internal/stacktrace/stack.go
String
called by 81
field.go
With
called by 81
zapcore/core.go
Write
called by 76
zapcore/core.go
nilField
called by 60
field.go

Shape

Function 626
Method 563
Struct 92
TypeAlias 53
Interface 24
FuncType 17

Languages

Go100%

Modules by API surface

zapcore/encoder.go88 symbols
array.go72 symbols
zapcore/json_encoder.go67 symbols
field.go57 symbols
zapcore/memory_encoder.go51 symbols
sugar.go49 symbols
logger_test.go36 symbols
zapcore/json_encoder_impl_test.go31 symbols
zapgrpc/zapgrpc.go29 symbols
logger_bench_test.go28 symbols
logger.go28 symbols
example_test.go22 symbols

Dependencies from manifests, versioned

github.com/apex/logv1.9.0 · 1×
github.com/davecgh/go-spewv1.1.1 · 1×
github.com/go-kit/logv0.2.1 · 1×
github.com/go-logfmt/logfmtv0.6.0 · 1×
github.com/go-stack/stackv1.8.1 · 1×
github.com/kr/prettyv0.3.0 · 1×
github.com/kr/textv0.2.0 · 1×
github.com/mattn/go-colorablev0.1.13 · 1×
github.com/mattn/go-isattyv0.0.19 · 1×
github.com/pmezard/go-difflibv1.0.0 · 1×
github.com/rogpeppe/go-internalv1.8.0 · 1×

For agents

$ claude mcp add zap \
  -- python -m otcore.mcp_server <graph>

⬇ download graph artifact