Skip to content

Commit

Permalink
vexplain to protect the log fields from concurrent writes (#17460)
Browse files Browse the repository at this point in the history
Signed-off-by: Harshit Gangal <[email protected]>
  • Loading branch information
harshit-gangal committed Jan 6, 2025
1 parent e7af629 commit 9b1d566
Showing 1 changed file with 21 additions and 10 deletions.
31 changes: 21 additions & 10 deletions go/vt/vtgate/vcursor_impl.go
Original file line number Diff line number Diff line change
Expand Up @@ -22,6 +22,7 @@ import (
"io"
"sort"
"strings"
"sync"
"sync/atomic"
"time"

Expand Down Expand Up @@ -133,6 +134,8 @@ type (

resultsObserver resultsObserver

// this protects the interOpStats and shardsStats fields from concurrent writes
mu sync.Mutex
// this is a map of the number of rows that every primitive has returned
// if this field is nil, it means that we are not logging operator traffic
interOpStats map[engine.Primitive]engine.RowsReceived
Expand Down Expand Up @@ -537,21 +540,29 @@ func (vc *vcursorImpl) ExecutePrimitive(ctx context.Context, primitive engine.Pr
}

func (vc *vcursorImpl) logOpTraffic(primitive engine.Primitive, res *sqltypes.Result) {
if vc.interOpStats != nil {
rows := vc.interOpStats[primitive]
if res == nil {
rows = append(rows, 0)
} else {
rows = append(rows, len(res.Rows))
}
vc.interOpStats[primitive] = rows
if vc.interOpStats == nil {
return
}

vc.mu.Lock()
defer vc.mu.Unlock()

rows := vc.interOpStats[primitive]
if res == nil {
rows = append(rows, 0)
} else {
rows = append(rows, len(res.Rows))
}
vc.interOpStats[primitive] = rows
}

func (vc *vcursorImpl) logShardsQueried(primitive engine.Primitive, shardsNb int) {
if vc.shardsStats != nil {
vc.shardsStats[primitive] += engine.ShardsQueried(shardsNb)
if vc.shardsStats == nil {
return
}
vc.mu.Lock()
defer vc.mu.Unlock()
vc.shardsStats[primitive] += engine.ShardsQueried(shardsNb)
}

func (vc *vcursorImpl) ExecutePrimitiveStandalone(ctx context.Context, primitive engine.Primitive, bindVars map[string]*querypb.BindVariable, wantfields bool) (*sqltypes.Result, error) {
Expand Down

0 comments on commit 9b1d566

Please sign in to comment.