Skip to content

Commit

Permalink
Merge pull request #1145 from sirupsen/custom_buffer_pool
Browse files Browse the repository at this point in the history
Add an API to plug a custom buffer free item mangement system
  • Loading branch information
dgsb authored May 28, 2020
2 parents 42baed8 + 64a5944 commit 6699a89
Show file tree
Hide file tree
Showing 2 changed files with 57 additions and 9 deletions.
52 changes: 52 additions & 0 deletions buffer_pool.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,52 @@
package logrus

import (
"bytes"
"sync"
)

var (
bufferPool BufferPool
)

type BufferPool interface {
Put(*bytes.Buffer)
Get() *bytes.Buffer
}

type defaultPool struct {
pool *sync.Pool
}

func (p *defaultPool) Put(buf *bytes.Buffer) {
p.pool.Put(buf)
}

func (p *defaultPool) Get() *bytes.Buffer {
return p.pool.Get().(*bytes.Buffer)
}

func getBuffer() *bytes.Buffer {
return bufferPool.Get()
}

func putBuffer(buf *bytes.Buffer) {
buf.Reset()
bufferPool.Put(buf)
}

// SetBufferPool allows to replace the default logrus buffer pool
// to better meets the specific needs of an application.
func SetBufferPool(bp BufferPool) {
bufferPool = bp
}

func init() {
SetBufferPool(&defaultPool{
pool: &sync.Pool{
New: func() interface{} {
return new(bytes.Buffer)
},
},
})
}
14 changes: 5 additions & 9 deletions entry.go
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,6 @@ import (
)

var (
bufferPool *sync.Pool

// qualified package name, cached at first use
logrusPackage string
Expand All @@ -31,12 +30,6 @@ const (
)

func init() {
bufferPool = &sync.Pool{
New: func() interface{} {
return new(bytes.Buffer)
},
}

// start at the bottom of the stack before the package-name cache is primed
minimumCallerDepth = 1
}
Expand Down Expand Up @@ -243,9 +236,12 @@ func (entry Entry) log(level Level, msg string) {

entry.fireHooks()

buffer = bufferPool.Get().(*bytes.Buffer)
buffer = getBuffer()
defer func() {
entry.Buffer = nil
putBuffer(buffer)
}()
buffer.Reset()
defer bufferPool.Put(buffer)
entry.Buffer = buffer

entry.write()
Expand Down

0 comments on commit 6699a89

Please sign in to comment.