Skip to content

Commit

Permalink
Log periodically if transaction takes long
Browse files Browse the repository at this point in the history
  • Loading branch information
hifi committed Mar 8, 2024
1 parent e5cb5e9 commit 8cc7a18
Showing 1 changed file with 30 additions and 7 deletions.
37 changes: 30 additions & 7 deletions dbutil/transaction.go
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,7 @@ import (
"database/sql"
"errors"
"fmt"
"runtime"
"time"

"github.com/rs/zerolog"
Expand Down Expand Up @@ -53,19 +54,41 @@ func (db *Database) DoTxn(ctx context.Context, opts *sql.TxOptions, fn func(ctx
zerolog.Ctx(ctx).Trace().Msg("Already in a transaction, not creating a new one")
return fn(ctx)
}
log := zerolog.Ctx(ctx).With().Str("db_txn_id", random.String(12)).Logger()

logWith := zerolog.Ctx(ctx).With().Str("db_txn_id", random.String(12))
val := ctx.Value(ContextKeyDoTxnCallerSkip)
callerSkip := 1
if val != nil {
callerSkip += val.(int)
}
pc, file, line, ok := runtime.Caller(callerSkip)
if ok {
logWith = logWith.Str(zerolog.CallerFieldName, zerolog.CallerMarshalFunc(pc, file, line))
}
log := logWith.Logger()

start := time.Now()
deadlockCh := make(chan struct{})

runtime.Caller(callerSkip)
go func() {
for {
select {
case <-time.After(time.Second * 5):
log.Warn().
Dur("duration_seconds", time.Since(start)).
Msg("Transaction still running")
case <-deadlockCh:
return
}
}
}()
defer func() {
close(deadlockCh)
dur := time.Since(start)
if dur > time.Second {
val := ctx.Value(ContextKeyDoTxnCallerSkip)
callerSkip := 2
if val != nil {
callerSkip += val.(int)
}
log.Warn().
Float64("duration_seconds", dur.Seconds()).
Caller(callerSkip).
Msg("Transaction took long")
}
}()
Expand Down

0 comments on commit 8cc7a18

Please sign in to comment.