Skip to content

Commit

Permalink
Merge pull request #126217 from cockroachdb/blathers/backport-release…
Browse files Browse the repository at this point in the history
…-23.1-99315

release-23.1: txnwait: do not require vmodule to log deadlocks in a workload
  • Loading branch information
arulajmani authored Jul 9, 2024
2 parents 94f0a47 + 4da56ae commit 3407242
Showing 1 changed file with 14 additions and 4 deletions.
18 changes: 14 additions & 4 deletions pkg/kv/kvserver/txnwait/queue.go
Original file line number Diff line number Diff line change
Expand Up @@ -227,8 +227,9 @@ type TestingKnobs struct {
//
// Queue is thread safe.
type Queue struct {
cfg Config
mu struct {
cfg Config
every log.EveryN // dictates logging for transaction aborts resulting from deadlock detection
mu struct {
syncutil.RWMutex
txns map[uuid.UUID]*pendingTxn
queries map[uuid.UUID]*waitingQueries
Expand All @@ -237,7 +238,10 @@ type Queue struct {

// NewQueue instantiates a new Queue.
func NewQueue(cfg Config) *Queue {
return &Queue{cfg: cfg}
return &Queue{
cfg: cfg,
every: log.Every(1 * time.Second),
}
}

// Enable allows transactions to be enqueued and waiting pushers
Expand Down Expand Up @@ -719,9 +723,15 @@ func (q *Queue) waitForPush(
// Break the deadlock if the pusher has higher priority.
p1, p2 := pusheePriority, pusherPriority
if p1 < p2 || (p1 == p2 && bytes.Compare(req.PusheeTxn.ID.GetBytes(), req.PusherTxn.ID.GetBytes()) < 0) {
// NB: It's useful to have logs indicating the transactions involved
// in a deadlock, but we don't want these to be too spammy.
level := log.Level(1)
if q.every.ShouldLog() {
level = 0 // will behave like a log.Infof
}
log.VEventf(
ctx,
1,
level,
"%s breaking deadlock by force push of %s; dependencies=%s",
req.PusherTxn.ID.Short(),
req.PusheeTxn.ID.Short(),
Expand Down

0 comments on commit 3407242

Please sign in to comment.