Files
tidb/pkg/kv/option.go

290 lines
11 KiB
Go

// Copyright 2021 PingCAP, Inc.
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
package kv
import (
"context"
"github.com/pingcap/errors"
"github.com/tikv/client-go/v2/util"
)
// Transaction options
const (
// BinlogInfo contains the binlog data and client.
BinlogInfo int = iota + 1
// SchemaChecker is used for checking schema-validity.
SchemaChecker
// IsolationLevel sets isolation level for current transaction. The default level is SI.
IsolationLevel
// Priority marks the priority of this transaction.
Priority
// NotFillCache makes this request do not touch the LRU cache of the underlying storage.
NotFillCache
// SyncLog is not used anymore.
SyncLog
// KeyOnly retrieve only keys, it can be used in scan now.
KeyOnly
// Pessimistic is defined for pessimistic lock
Pessimistic
// SnapshotTS is defined to set snapshot ts.
SnapshotTS
// ReplicaRead Set replica read
ReplicaRead
// TaskID Set task ID
TaskID
// InfoSchema is schema version used by txn startTS.
InfoSchema
// CollectRuntimeStats is used to enable collect runtime stats.
CollectRuntimeStats
// SchemaAmender is used to amend mutations for pessimistic transactions
SchemaAmender
// SampleStep skips 'SampleStep - 1' number of keys after each returned key.
SampleStep
// CommitHook is a callback function called right after the transaction gets committed
CommitHook
// EnableAsyncCommit indicates whether async commit is enabled
EnableAsyncCommit
// Enable1PC indicates whether one-phase commit is enabled
Enable1PC
// GuaranteeLinearizability indicates whether to guarantee linearizability at the cost of an extra tso request before prewrite
GuaranteeLinearizability
// TxnScope indicates which @@txn_scope this transaction will work with.
TxnScope
// ReadReplicaScope
ReadReplicaScope
// IsStalenessReadOnly indicates whether the transaction is staleness read only transaction
IsStalenessReadOnly
// MatchStoreLabels indicates the labels the store should be matched
MatchStoreLabels
// ResourceGroupTag indicates the resource group tag of the kv request.
ResourceGroupTag
// ResourceGroupTagger can be used to set the ResourceGroupTag dynamically according to the request content. It will be used only when ResourceGroupTag is nil.
ResourceGroupTagger
// KVFilter indicates the filter to ignore key-values in the transaction's memory buffer.
KVFilter
// SnapInterceptor is used for setting the interceptor for snapshot
SnapInterceptor
// CommitTSUpperBoundCheck is used by cached table
// The commitTS must be greater than all the write lock lease of the visited cached table.
CommitTSUpperBoundCheck
// RPCInterceptor is interceptor.RPCInterceptor on Transaction or Snapshot, used to decorate
// additional logic before and after the underlying client-go RPC request.
RPCInterceptor
// TableToColumnMaps is a map from tableID to a series of maps. The maps are needed when checking data consistency.
// Save them here to reduce redundant computations.
TableToColumnMaps
// AssertionLevel controls how strict the assertions on data during transactions should be.
AssertionLevel
// RequestSourceInternal set request source scope of transaction.
RequestSourceInternal
// RequestSourceType set request source type of the current statement.
RequestSourceType
// ExplicitRequestSourceType is a complement of RequestSourceType, it may specified by the client or users.
ExplicitRequestSourceType
// ReplicaReadAdjuster set the adjust function of cop requests.
ReplicaReadAdjuster
// ScanBatchSize set the iter scan batch size.
ScanBatchSize
// TxnSource set the source of this transaction.
// We use an uint64 to represent the source of a transaction.
// The first 8 bits are reserved for TiCDC to implement BDR synchronization,
// and the next 8 bits are reserved for Lossy DDL reorg Backfill job.
// The remaining 48 bits are reserved for extendability.
TxnSource
// ResourceGroupName set the bind resource group name.
ResourceGroupName
// LoadBasedReplicaReadThreshold sets the TiKV wait duration threshold of enabling replica read automatically.
LoadBasedReplicaReadThreshold
// TiKVClientReadTimeout sets the timeout value for readonly kv request in milliseconds
TiKVClientReadTimeout
// SizeLimits sets the size limits of membuf
SizeLimits
// SessionID marks the connection id, for logging and tracing.
SessionID
// BackgroundGoroutineLifecycleHooks is the hooks to track the start and end of background goroutine
BackgroundGoroutineLifecycleHooks
// PrewriteEncounterLockPolicy is the policy to handle lock conflict during prewrite
PrewriteEncounterLockPolicy
)
// TxnSizeLimits is the argument type for `SizeLimits` option
type TxnSizeLimits struct {
Entry uint64
Total uint64
}
// ReplicaReadType is the type of replica to read data from
type ReplicaReadType byte
const (
// ReplicaReadLeader stands for 'read from leader'.
ReplicaReadLeader ReplicaReadType = iota
// ReplicaReadFollower stands for 'read from follower'.
ReplicaReadFollower
// ReplicaReadMixed stands for 'read from leader and follower'.
ReplicaReadMixed
// ReplicaReadClosest stands for 'read from leader and follower which locates with the same zone'
ReplicaReadClosest
// ReplicaReadClosestAdaptive stands for 'read from follower which locates in the same zone if the response size exceeds certain threshold'
ReplicaReadClosestAdaptive
// ReplicaReadLearner stands for 'read from learner'.
ReplicaReadLearner
// ReplicaReadPreferLeader stands for 'read from leader and auto-turn to followers if leader is abnormal'.
ReplicaReadPreferLeader
)
// IsFollowerRead checks if follower is going to be used to read data.
func (r ReplicaReadType) IsFollowerRead() bool {
return r != ReplicaReadLeader
}
// IsClosestRead checks whether is going to request closet store to read
func (r ReplicaReadType) IsClosestRead() bool {
return r == ReplicaReadClosest
}
// RequestSourceKey is used as the key of request source type in context.
var RequestSourceKey = util.RequestSourceKey
// RequestSource is the scope and type of the request and it's passed by go context.
type RequestSource = util.RequestSource
// WithInternalSourceType create context with internal source.
var WithInternalSourceType = util.WithInternalSourceType
// WithInternalSourceAndTaskType create context with internal source and task name.
var WithInternalSourceAndTaskType = util.WithInternalSourceAndTaskType
// GetInternalSourceType get internal source
func GetInternalSourceType(ctx context.Context) string {
v := ctx.Value(util.RequestSourceKey)
if v == nil {
return ""
}
return v.(util.RequestSource).RequestSourceType
}
const (
// InternalTxnOthers is the type of requests that consume low resources.
// This reduces the size of metrics.
InternalTxnOthers = util.InternalTxnOthers
// InternalTxnGC is the type of GC txn.
InternalTxnGC = util.InternalTxnGC
// InternalTxnBootstrap is the type of TiDB bootstrap txns.
InternalTxnBootstrap = InternalTxnOthers
// InternalTxnMeta is the type of the miscellaneous meta usage.
InternalTxnMeta = util.InternalTxnMeta
// InternalTxnDDL is the type of inner txns in ddl module.
InternalTxnDDL = "ddl"
// InternalTxnBackfillDDLPrefix is the prefix of the types of DDL operations needs backfilling.
InternalTxnBackfillDDLPrefix = "ddl_"
// InternalTxnCacheTable is the type of cache table usage.
InternalTxnCacheTable = InternalTxnOthers
// InternalTxnStats is the type of statistics txn.
InternalTxnStats = "stats"
// InternalTxnBindInfo is the type of bind info txn.
InternalTxnBindInfo = InternalTxnOthers
// InternalTxnWorkloadLearning is the type of workload-based learning txn.
InternalTxnWorkloadLearning = "WorkloadLearning"
// InternalTxnSysVar is the type of sys var txn.
InternalTxnSysVar = InternalTxnOthers
// InternalTxnTelemetry is the type of telemetry.
InternalTxnTelemetry = InternalTxnOthers
// InternalTxnAdmin is the type of admin operations.
InternalTxnAdmin = "admin"
// InternalTxnPrivilege is the type of privilege txn.
InternalTxnPrivilege = InternalTxnOthers
// InternalTxnTools is the type of tools usage of TiDB.
// Do not classify different tools by now.
InternalTxnTools = "tools"
// InternalTxnBR is the type of BR usage.
InternalTxnBR = "br"
// InternalTxnLightning is the type of Lightning usage.
InternalTxnLightning = "lightning"
// InternalTxnTrace handles the trace statement.
InternalTxnTrace = "Trace"
// InternalTxnTTL is the type of TTL usage
InternalTxnTTL = "TTL"
// InternalLoadData is the type of LOAD DATA usage
InternalLoadData = "LoadData"
// InternalImportInto is the type of IMPORT INTO usage
InternalImportInto = "ImportInto"
// InternalDistTask is the type of distributed task.
InternalDistTask = "DistTask"
// InternalTimer is the type of internal timer
InternalTimer = "Timer"
// InternalDDLNotifier is the type of DDL notifier
InternalDDLNotifier = "DDLNotifier"
)
// The bitmap:
// |RESERVED|LOSSY_DDL_REORG_SOURCE_BITS|CDC_WRITE_SOURCE_BITS|
// | 48 | 8 | 4(RESERVED) | 4 |
const (
// TiCDC uses 1 - 255 to indicate the source of TiDB.
// For now, 1 - 15 are reserved for TiCDC to implement BDR synchronization.
// 16 - 255 are reserved for extendability.
cdcWriteSourceBits = 8
cdcWriteSourceMax = (1 << cdcWriteSourceBits) - 1
// TiCDC uses 1-255 to indicate the change from a lossy DDL reorg Backfill job.
// For now, we only use 1 for column reorg backfill job.
lossyDDLReorgSourceBits = 8
LossyDDLColumnReorgSource = 1
lossyDDLReorgSourceMax = (1 << lossyDDLReorgSourceBits) - 1
lossyDDLReorgSourceShift = cdcWriteSourceBits
// LightningPhysicalImportTxnSource the 17th bit is set as the txn source for Lightning physical import.
LightningPhysicalImportTxnSource = 1 << 16
)
// SetCDCWriteSource sets the TiCDC write source in the txnSource.
func SetCDCWriteSource(txnSource *uint64, value uint64) error {
if value > cdcWriteSourceBits {
return errors.Errorf("value %d is out of TiCDC write source range, should be in [1, 15]",
value)
}
*txnSource |= value
return nil
}
func getCDCWriteSource(txnSource uint64) uint64 {
return txnSource & cdcWriteSourceMax
}
func isCDCWriteSourceSet(txnSource uint64) bool {
return (txnSource & cdcWriteSourceMax) != 0
}
// SetLossyDDLReorgSource sets the lossy DDL reorg source in the txnSource.
func SetLossyDDLReorgSource(txnSource *uint64, value uint64) error {
if value > lossyDDLReorgSourceMax {
return errors.Errorf("value %d is out of lossy DDL reorg source range, should be in [1, %d]",
value, lossyDDLReorgSourceMax)
}
*txnSource |= value << lossyDDLReorgSourceShift
return nil
}
func getLossyDDLReorgSource(txnSource uint64) uint64 {
return (txnSource >> lossyDDLReorgSourceShift) & lossyDDLReorgSourceMax
}
func isLossyDDLReorgSourceSet(txnSource uint64) bool {
return (txnSource >> lossyDDLReorgSourceShift) != 0
}