Skip to content

Commit

Permalink
table: use pooled writers (#596)
Browse files Browse the repository at this point in the history
  • Loading branch information
asubiotto authored Nov 27, 2023
1 parent 70142b9 commit 7c5f494
Show file tree
Hide file tree
Showing 2 changed files with 13 additions and 9 deletions.
15 changes: 8 additions & 7 deletions table.go
Original file line number Diff line number Diff line change
Expand Up @@ -939,12 +939,8 @@ type parquetRowWriter struct {
type parquetRowWriterOption func(p *parquetRowWriter)

// rowWriter returns a new Parquet row writer with the given dynamic columns.
func (t *TableBlock) rowWriter(writer io.Writer, dynCols map[string][]string, options ...parquetRowWriterOption) (*parquetRowWriter, error) {
w, err := t.table.schema.NewWriter(writer, dynCols, false)
if err != nil {
return nil, err
}

// TODO(asubiotto): Can we delete this parquetRowWriter?
func (t *TableBlock) rowWriter(w ParquetWriter, options ...parquetRowWriterOption) (*parquetRowWriter, error) {
buffSize := 256
if t.table.config.RowGroupSize > 0 {
buffSize = int(t.table.config.RowGroupSize)
Expand Down Expand Up @@ -1199,7 +1195,12 @@ func (t *Table) compactParts(w io.Writer, compact []*parts.Part) (int64, error)
return 0, err
}
err = func() error {
p, err := t.active.rowWriter(w, merged.DynamicColumns())
pw, err := t.schema.GetWriter(w, merged.DynamicColumns(), false)
if err != nil {
return err
}
defer t.schema.PutWriter(pw)
p, err := t.active.rowWriter(pw)
if err != nil {
return err
}
Expand Down
7 changes: 5 additions & 2 deletions table_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -739,9 +739,12 @@ func Test_RowWriter(t *testing.T) {
defer c.Close()

b := &bytes.Buffer{}
rowWriter, err := table.ActiveBlock().rowWriter(b, map[string][]string{
pw, err := table.schema.GetWriter(b, map[string][]string{
"labels": {"node"},
})
}, false)
defer table.schema.PutWriter(pw)
require.NoError(t, err)
rowWriter, err := table.ActiveBlock().rowWriter(pw)
require.NoError(t, err)

// Write 17(8,9) rows, expect 3 row groups of 5 rows and 1 row group of 2 rows
Expand Down

0 comments on commit 7c5f494

Please sign in to comment.