Documentation ¶
Index ¶
- Variables
- func AddAssertEntranceForLockError(sctx sessionctx.Context, name string)
- func AssertTxnManagerInfoSchema(sctx sessionctx.Context, is interface{})
- func AssertTxnManagerReadTS(sctx sessionctx.Context, expected uint64)
- func ExecTestHook(sctx sessionctx.Context, hookKey fmt.Stringer)
- func NewTxn(ctx context.Context, sctx sessionctx.Context) error
- func NewTxnInStmt(ctx context.Context, sctx sessionctx.Context) error
- func OnStmtRetryCountInc(sctx sessionctx.Context)
- func OptimizeWithPlanAndThenWarmUp(sctx sessionctx.Context, plan interface{}) error
- func RecordAssert(sctx sessionctx.Context, name string, value interface{})
- func TsoRequestCountInc(sctx sessionctx.Context)
- func TsoUseConstantCountInc(sctx sessionctx.Context)
- func TsoWaitCountInc(sctx sessionctx.Context)
- type ConstantFuture
- type EnterNewTxnRequest
- type EnterNewTxnType
- type StmtErrorAction
- type StmtErrorHandlePoint
- type TxnAdvisable
- type TxnContextProvider
- type TxnManager
Constants ¶
This section is empty.
Variables ¶
var AssertLockErr stringutil.StringerStr = "assertLockError"
AssertLockErr is used to record the lock errors we encountered Only for test
var AssertRecordsKey stringutil.StringerStr = "assertTxnManagerRecords"
AssertRecordsKey is used to save failPoint invoke records Only for test
var AssertTxnInfoSchemaAfterRetryKey stringutil.StringerStr = "assertTxnInfoSchemaAfterRetryKey"
AssertTxnInfoSchemaAfterRetryKey is used to set the expected infoschema that should be check in failPoint after retry Only for test
var AssertTxnInfoSchemaKey stringutil.StringerStr = "assertTxnInfoSchemaKey"
AssertTxnInfoSchemaKey is used to set the expected infoschema that should be check in failPoint Only for test
var BreakPointBeforeExecutorFirstRun = "beforeExecutorFirstRun"
BreakPointBeforeExecutorFirstRun is the key for the stop point where session stops before executor's first run Only for test
var BreakPointOnStmtRetryAfterLockError = "lockErrorAndThenOnStmtRetryCalled"
BreakPointOnStmtRetryAfterLockError s the key for the stop point where session stops after OnStmtRetry when lock error happens Only for test
var CallOnStmtRetryCount stringutil.StringerStr = "callOnStmtRetryCount"
CallOnStmtRetryCount is the key for recording calling OnStmtRetry at RC isolation level
var GetTxnManager func(sctx sessionctx.Context) TxnManager
GetTxnManager returns the TxnManager object from session context
var TsoRequestCount stringutil.StringerStr = "tsoRequestCount"
TsoRequestCount is the key for recording tso request counts in some places
var TsoUseConstantCount stringutil.StringerStr = "tsoUseConstantCount"
TsoUseConstantCount is the key for constant tso counter
var TsoWaitCount stringutil.StringerStr = "tsoWaitCount"
TsoWaitCount doesn't include begin and commit
Functions ¶
func AddAssertEntranceForLockError ¶
func AddAssertEntranceForLockError(sctx sessionctx.Context, name string)
AddAssertEntranceForLockError is used only for test
func AssertTxnManagerInfoSchema ¶
func AssertTxnManagerInfoSchema(sctx sessionctx.Context, is interface{})
AssertTxnManagerInfoSchema is used only for test
func AssertTxnManagerReadTS ¶
func AssertTxnManagerReadTS(sctx sessionctx.Context, expected uint64)
AssertTxnManagerReadTS is used only for test
func ExecTestHook ¶
func ExecTestHook(sctx sessionctx.Context, hookKey fmt.Stringer)
ExecTestHook is used only for test. It consumes hookKey in session wait do what it gets from it.
func NewTxn ¶
func NewTxn(ctx context.Context, sctx sessionctx.Context) error
NewTxn starts a new optimistic and active txn, it can be used for the below scenes: 1. Commit the current transaction and do some work in a new transaction for some specific operations, for example: DDL 2. Some background job need to do something in a transaction. In other scenes like 'BEGIN', 'START TRANSACTION' or prepare transaction in a new statement, you should use `TxnManager`.`EnterNewTxn` and pass the relevant to it.
func NewTxnInStmt ¶
func NewTxnInStmt(ctx context.Context, sctx sessionctx.Context) error
NewTxnInStmt is like `NewTxn` but it will call `OnStmtStart` after it. It should be used when a statement already started.
func OnStmtRetryCountInc ¶
func OnStmtRetryCountInc(sctx sessionctx.Context)
OnStmtRetryCountInc is used only for test. When it is called, there is calling `(p *PessimisticRCTxnContextProvider) OnStmtRetry`.
func OptimizeWithPlanAndThenWarmUp ¶
func OptimizeWithPlanAndThenWarmUp(sctx sessionctx.Context, plan interface{}) error
OptimizeWithPlanAndThenWarmUp first do `AdviseOptimizeWithPlan` to optimize the txn with plan and then do `AdviseWarmup` to do some tso fetch if necessary
func RecordAssert ¶
func RecordAssert(sctx sessionctx.Context, name string, value interface{})
RecordAssert is used only for test
func TsoRequestCountInc ¶
func TsoRequestCountInc(sctx sessionctx.Context)
TsoRequestCountInc is used only for test When it is called, there is a tso cmd request.
func TsoUseConstantCountInc ¶
func TsoUseConstantCountInc(sctx sessionctx.Context)
TsoUseConstantCountInc is used to test constant tso count
func TsoWaitCountInc ¶
func TsoWaitCountInc(sctx sessionctx.Context)
TsoWaitCountInc is used only for test When it is called, there is a waiting tso operation
Types ¶
type ConstantFuture ¶
type ConstantFuture uint64
ConstantFuture implements oracle.Future
func (ConstantFuture) Wait ¶
func (n ConstantFuture) Wait() (uint64, error)
Wait returns a constant ts
type EnterNewTxnRequest ¶
type EnterNewTxnRequest struct { // Type is the type for new entering a new txn Type EnterNewTxnType // provider is the context provider Provider TxnContextProvider // txnMode is the transaction mode for the new txn. It has 3 values: `ast.Pessimistic` ,`ast.Optimistic` or empty/ // When the value is empty, it means the value will be determined from sys vars. TxnMode string // causalConsistencyOnly means whether enable causal consistency for transactions, default is false CausalConsistencyOnly bool // staleReadTS indicates the read ts for the stale read transaction. // The default value is zero which means not a stale read transaction. StaleReadTS uint64 }
EnterNewTxnRequest is the request when entering a new transaction
type EnterNewTxnType ¶
type EnterNewTxnType int
EnterNewTxnType is the type to enter a new txn
const ( // EnterNewTxnDefault means to enter a new txn. Its behavior is more straight-forward // just starting a new txn right now without any scenario assumptions. EnterNewTxnDefault EnterNewTxnType = iota // EnterNewTxnWithBeginStmt indicates to enter a new txn when execute 'BEGIN' or 'START TRANSACTION' EnterNewTxnWithBeginStmt // EnterNewTxnBeforeStmt indicates to enter a new txn before each statement when the txn is not present // If `EnterNewTxnBeforeStmt` is used, the new txn will always act as the 'lazy' mode. That means the inner transaction // is only activated when needed to reduce unnecessary overhead. EnterNewTxnBeforeStmt // EnterNewTxnWithReplaceProvider indicates to replace the current provider. Now only stale read are using this EnterNewTxnWithReplaceProvider )
type StmtErrorAction ¶
type StmtErrorAction int
StmtErrorAction is the next action advice when an error occurs when executing a statement
const ( // StmtActionError means the error should be returned directly without any retry StmtActionError StmtErrorAction = iota // StmtActionRetryReady means the error is caused by this component, and it is ready for retry. StmtActionRetryReady // StmtActionNoIdea means the error is not caused by this component, and whether retry or not should be determined by other components. // If the user do not know whether to retry or not, it is advised to return the original error. StmtActionNoIdea )
func ErrorAction ¶
func ErrorAction(err error) (StmtErrorAction, error)
ErrorAction returns StmtActionError with specified error
func RetryReady ¶
func RetryReady() (StmtErrorAction, error)
RetryReady returns StmtActionRetryReady, nil
type StmtErrorHandlePoint ¶
type StmtErrorHandlePoint int
StmtErrorHandlePoint is where the error is being handled
const ( // StmtErrAfterQuery means we are handling an error after the query failed StmtErrAfterQuery StmtErrorHandlePoint = iota // StmtErrAfterPessimisticLock means we are handling an error after pessimistic lock failed. StmtErrAfterPessimisticLock )
type TxnAdvisable ¶
type TxnAdvisable interface { // AdviseWarmup provides warmup for inner state AdviseWarmup() error // AdviseOptimizeWithPlan providers optimization according to the plan AdviseOptimizeWithPlan(plan interface{}) error }
TxnAdvisable providers a collection of optimizations within transaction
type TxnContextProvider ¶
type TxnContextProvider interface { TxnAdvisable // GetTxnInfoSchema returns the information schema used by txn GetTxnInfoSchema() infoschema.InfoSchema // SetTxnInfoSchema sets the information schema used by txn. SetTxnInfoSchema(is infoschema.InfoSchema) // GetTxnScope returns the current txn scope GetTxnScope() string // GetReadReplicaScope returns the read replica scope GetReadReplicaScope() string // GetStmtReadTS returns the read timestamp used by select statement (not for select ... for update) GetStmtReadTS() (uint64, error) // GetStmtForUpdateTS returns the read timestamp used by update/insert/delete or select ... for update GetStmtForUpdateTS() (uint64, error) // GetSnapshotWithStmtReadTS gets snapshot with read ts GetSnapshotWithStmtReadTS() (kv.Snapshot, error) // GetSnapshotWithStmtForUpdateTS gets snapshot with for update ts GetSnapshotWithStmtForUpdateTS() (kv.Snapshot, error) // OnInitialize is the hook that should be called when enter a new txn with this provider OnInitialize(ctx context.Context, enterNewTxnType EnterNewTxnType) error // OnStmtStart is the hook that should be called when a new statement started OnStmtStart(ctx context.Context, node ast.StmtNode) error // OnPessimisticStmtStart is the hook that should be called when starts handling a pessimistic DML or // a pessimistic select-for-update statement. OnPessimisticStmtStart(ctx context.Context) error // OnPessimisticStmtEnd is the hook that should be called when finishes handling a pessimistic DML or // select-for-update statement. OnPessimisticStmtEnd(ctx context.Context, isSuccessful bool) error // OnStmtErrorForNextAction is the hook that should be called when a new statement get an error OnStmtErrorForNextAction(ctx context.Context, point StmtErrorHandlePoint, err error) (StmtErrorAction, error) // OnStmtRetry is the hook that should be called when a statement is retried internally. OnStmtRetry(ctx context.Context) error // OnStmtCommit is the hook that should be called when a statement is executed successfully. OnStmtCommit(ctx context.Context) error // OnStmtRollback is the hook that should be called when a statement fails to execute. OnStmtRollback(ctx context.Context, isForPessimisticRetry bool) error // OnLocalTemporaryTableCreated is the hook that should be called when a local temporary table created. OnLocalTemporaryTableCreated() // ActivateTxn activates the transaction. ActivateTxn() (kv.Transaction, error) }
TxnContextProvider provides txn context
type TxnManager ¶
type TxnManager interface { TxnAdvisable // GetTxnInfoSchema returns the information schema used by txn // If the session is not in any transaction, for example: between two autocommit statements, // this method will return the latest information schema in session that is same with `sessionctx.GetDomainInfoSchema()` GetTxnInfoSchema() infoschema.InfoSchema // SetTxnInfoSchema sets the information schema used by txn. SetTxnInfoSchema(infoschema.InfoSchema) // GetTxnScope returns the current txn scope GetTxnScope() string // GetReadReplicaScope returns the read replica scope GetReadReplicaScope() string // GetStmtReadTS returns the read timestamp used by select statement (not for select ... for update) // Calling this method will activate the txn implicitly if current read is not stale/historical read GetStmtReadTS() (uint64, error) // GetStmtForUpdateTS returns the read timestamp used by update/insert/delete or select ... for update // Calling this method will activate the txn implicitly if current read is not stale/historical read GetStmtForUpdateTS() (uint64, error) // GetContextProvider returns the current TxnContextProvider GetContextProvider() TxnContextProvider // GetSnapshotWithStmtReadTS gets snapshot with read ts GetSnapshotWithStmtReadTS() (kv.Snapshot, error) // GetSnapshotWithStmtForUpdateTS gets snapshot with for update ts GetSnapshotWithStmtForUpdateTS() (kv.Snapshot, error) // EnterNewTxn enters a new transaction. EnterNewTxn(ctx context.Context, req *EnterNewTxnRequest) error // OnTxnEnd is the hook that should be called after transaction commit or rollback OnTxnEnd() // OnStmtStart is the hook that should be called when a new statement started OnStmtStart(ctx context.Context, node ast.StmtNode) error // OnPessimisticStmtStart is the hook that should be called when starts handling a pessimistic DML or // a pessimistic select-for-update statement. OnPessimisticStmtStart(ctx context.Context) error // OnPessimisticStmtEnd is the hook that should be called when finishes handling a pessimistic DML or // select-for-update statement. OnPessimisticStmtEnd(ctx context.Context, isSuccessful bool) error // OnStmtErrorForNextAction is the hook that should be called when a new statement get an error // This method is not required to be called for every error in the statement, // it is only required to be called for some errors handled in some specified points given by the parameter `point`. // When the return error is not nil the return action is 'StmtActionError' and vice versa. OnStmtErrorForNextAction(ctx context.Context, point StmtErrorHandlePoint, err error) (StmtErrorAction, error) // OnStmtRetry is the hook that should be called when a statement retry OnStmtRetry(ctx context.Context) error // OnStmtCommit is the hook that should be called when a statement is executed successfully. OnStmtCommit(ctx context.Context) error // OnStmtRollback is the hook that should be called when a statement fails to execute. OnStmtRollback(ctx context.Context, isForPessimisticRetry bool) error // OnStmtEnd is called when a statement ends, together with txn.onStmtEnd() OnStmtEnd() // OnLocalTemporaryTableCreated is the hook that should be called when a local temporary table created. OnLocalTemporaryTableCreated() // ActivateTxn activates the transaction. ActivateTxn() (kv.Transaction, error) // GetCurrentStmt returns the current statement node GetCurrentStmt() ast.StmtNode }
TxnManager is an interface providing txn context management in session