package diode
import "github.com/rs/zerolog/diode"
Package diode provides a thread-safe, lock-free, non-blocking io.Writer wrapper.
Index ¶
Examples ¶
Types ¶
type Writer ¶
type Writer struct {
// contains filtered or unexported fields
}
Writer is a io.Writer wrapper that uses a diode to make Write lock-free, non-blocking and thread safe.
func NewWriter ¶
NewWriter creates a writer wrapping w with a many-to-one diode in order to never block log producers and drop events if the writer can't keep up with the flow of data.
Use a diode.Writer when
d := diodes.NewManyToOne(1000, diodes.AlertFunc(func(missed int) { log.Printf("Dropped %d messages", missed) })) w := diode.NewWriter(w, d, 10 * time.Millisecond) log := zerolog.New(w)
See code.cloudfoundry.org/go-diodes for more info on diode.
Code:play
Output:Example¶
package main
import (
"fmt"
"os"
"time"
diodes "code.cloudfoundry.org/go-diodes"
"github.com/rs/zerolog"
"github.com/rs/zerolog/diode"
)
func main() {
d := diodes.NewManyToOne(1000, diodes.AlertFunc(func(missed int) {
fmt.Printf("Dropped %d messages\n", missed)
}))
w := diode.NewWriter(os.Stdout, d, 10*time.Millisecond)
log := zerolog.New(w)
log.Print("test")
w.Close()
}
{"level":"debug","message":"test"}
func (Writer) Close ¶
Close releases the diode poller and call Close on the wrapped writer if io.Closer is implemented.
func (Writer) Write ¶
Source Files ¶
- Version
- v1.6.0
- Published
- Mar 28, 2018
- Platform
- linux/amd64
- Imports
- 5 packages
- Last checked
- 3 days ago –
Tools for package owners.