mirror of
https://github.com/minio/minio.git
synced 2025-01-25 21:53:16 -05:00
metacache: Always close block writer (#10973)
In some cases a writer could be left behind unclosed, leaking compression blocks. Always close and set compression concurrency to 2 which should be fine to keep up.
This commit is contained in:
parent
31e6f60847
commit
0422eda6a2
@ -76,7 +76,7 @@ func newMetacacheWriter(out io.Writer, blockSize int) *metacacheWriter {
|
||||
blockSize: blockSize,
|
||||
}
|
||||
w.creator = func() error {
|
||||
s2w := s2.NewWriter(out, s2.WriterBlockSize(blockSize))
|
||||
s2w := s2.NewWriter(out, s2.WriterBlockSize(blockSize), s2.WriterConcurrency(2))
|
||||
w.mw = msgp.NewWriter(s2w)
|
||||
w.creator = nil
|
||||
if err := w.mw.WriteByte(metacacheStreamVersion); err != nil {
|
||||
@ -206,7 +206,7 @@ func (w *metacacheWriter) Close() error {
|
||||
func (w *metacacheWriter) Reset(out io.Writer) {
|
||||
w.streamErr = nil
|
||||
w.creator = func() error {
|
||||
s2w := s2.NewWriter(out, s2.WriterBlockSize(w.blockSize))
|
||||
s2w := s2.NewWriter(out, s2.WriterBlockSize(w.blockSize), s2.WriterConcurrency(2))
|
||||
w.mw = msgp.NewWriter(s2w)
|
||||
w.creator = nil
|
||||
if err := w.mw.WriteByte(metacacheStreamVersion); err != nil {
|
||||
@ -757,6 +757,7 @@ func newMetacacheBlockWriter(in <-chan metaCacheEntry, nextBlock func(b *metacac
|
||||
var n int
|
||||
var buf bytes.Buffer
|
||||
block := newMetacacheWriter(&buf, 1<<20)
|
||||
defer block.Close()
|
||||
finishBlock := func() {
|
||||
err := block.Close()
|
||||
if err != nil {
|
||||
|
@ -370,6 +370,7 @@ func Test_newMetacacheStream(t *testing.T) {
|
||||
r := loadMetacacheSample(t)
|
||||
var buf bytes.Buffer
|
||||
w := newMetacacheWriter(&buf, 1<<20)
|
||||
defer w.Close()
|
||||
err := r.readFn(func(object metaCacheEntry) bool {
|
||||
err := w.write(object)
|
||||
if err != nil {
|
||||
|
Loading…
x
Reference in New Issue
Block a user