Skip to content

Commit

Permalink
session: track LastCommitTS in SessionVars and check StartTS of a txn…
Browse files Browse the repository at this point in the history
… is larger
  • Loading branch information
b6g committed Nov 11, 2024
1 parent 91436e3 commit e053b6f
Show file tree
Hide file tree
Showing 6 changed files with 41 additions and 0 deletions.
4 changes: 4 additions & 0 deletions pkg/kv/interface_mock_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -75,6 +75,10 @@ func (t *mockTxn) StartTS() uint64 {
return uint64(0)
}

func (t *mockTxn) CommitTS() uint64 {
return 0
}

func (t *mockTxn) Get(ctx context.Context, k Key) ([]byte, error) {
return nil, nil
}
Expand Down
2 changes: 2 additions & 0 deletions pkg/kv/kv.go
Original file line number Diff line number Diff line change
Expand Up @@ -251,6 +251,8 @@ type Transaction interface {
IsReadOnly() bool
// StartTS returns the transaction start timestamp.
StartTS() uint64
// CommitTS returns the transaction commit timestamp.
CommitTS() uint64
// Valid returns if the transaction is valid.
// A transaction become invalid after commit or rollback.
Valid() bool
Expand Down
15 changes: 15 additions & 0 deletions pkg/session/session.go
Original file line number Diff line number Diff line change
Expand Up @@ -929,6 +929,21 @@ func (s *session) CommitTxn(ctx context.Context) error {
s.sessionVars.StmtCtx.MergeExecDetails(nil, commitDetail)
}

if err == nil {
// save CommitTS in sessionVars for invariant check
// TODO: enable LastCommitTS with a session variable
if ts := s.txn.CommitTS(); ts > 0 {
if ts <= s.sessionVars.LastCommitTS {
logutil.BgLogger().Fatal("check lastCommitTS failed",
zap.Uint64("lastCommitTS", s.sessionVars.LastCommitTS),
zap.Uint64("CommitTS", ts),
)
} else {
s.sessionVars.LastCommitTS = ts
}
}
}

// record the TTLInsertRows in the metric
metrics.TTLInsertRowsCount.Add(float64(s.sessionVars.TxnCtx.InsertTTLRowsCount))

Expand Down
7 changes: 7 additions & 0 deletions pkg/session/txn.go
Original file line number Diff line number Diff line change
Expand Up @@ -231,6 +231,13 @@ func (txn *LazyTxn) validOrPending() bool {
return txn.txnFuture != nil || txn.Valid()
}

func (txn *LazyTxn) CommitTS() uint64 {
if txn.Transaction != nil {
return txn.Transaction.CommitTS()
}
return 0
}

func (txn *LazyTxn) String() string {
if txn.Transaction != nil {
return txn.Transaction.String()
Expand Down
3 changes: 3 additions & 0 deletions pkg/sessionctx/variable/session.go
Original file line number Diff line number Diff line change
Expand Up @@ -888,6 +888,9 @@ type SessionVars struct {
// SnapshotTS is used for reading history data. For simplicity, SnapshotTS only supports distsql request.
SnapshotTS uint64

// LastCommitTS is the commit_ts of the last transaction in this session.
LastCommitTS uint64

// TxnReadTS is used for staleness transaction, it provides next staleness transaction startTS.
TxnReadTS *TxnReadTS

Expand Down
10 changes: 10 additions & 0 deletions pkg/sessiontxn/isolation/base.go
Original file line number Diff line number Diff line change
Expand Up @@ -34,11 +34,13 @@ import (
"github.com/pingcap/tidb/pkg/store/driver/txn"
"github.com/pingcap/tidb/pkg/table/temptable"
"github.com/pingcap/tidb/pkg/tablecodec"
"github.com/pingcap/tidb/pkg/util/logutil"
"github.com/pingcap/tidb/pkg/util/tableutil"
"github.com/pingcap/tidb/pkg/util/tracing"
tikvstore "github.com/tikv/client-go/v2/kv"
"github.com/tikv/client-go/v2/oracle"
"github.com/tikv/client-go/v2/txnkv/transaction"
"go.uber.org/zap"
)

// baseTxnContextProvider is a base class for the transaction context providers that implement `TxnContextProvider` in different isolation.
Expand Down Expand Up @@ -304,6 +306,14 @@ func (p *baseTxnContextProvider) ActivateTxn() (kv.Transaction, error) {
sessVars.SetInTxn(true)
}

// verify start_ts is later than any previous commit_ts in the session
if sessVars.LastCommitTS > 0 && sessVars.LastCommitTS > sessVars.TxnCtx.StartTS {
logutil.BgLogger().Fatal("check lastCommitTS failed",
zap.Uint64("lastCommitTS", sessVars.LastCommitTS),
zap.Uint64("startTS", sessVars.TxnCtx.StartTS),
)
}

txn.SetVars(sessVars.KVVars)

p.SetOptionsOnTxnActive(txn)
Expand Down

0 comments on commit e053b6f

Please sign in to comment.