Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[DNM]GC: Support keyspace level GC #51300

Open
wants to merge 99 commits into
base: master
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
99 commits
Select commit Hold shift + click to select a range
026c7b1
support gc v2
ystaticy Feb 26, 2024
b7f3d48
make bazel_prepare
ystaticy Feb 27, 2024
e262183
make bazel_prepare
ystaticy Feb 27, 2024
c439e9e
fix curremtn min ts
ystaticy Feb 28, 2024
6eb412d
code format
ystaticy Mar 4, 2024
ffe2a29
add check safe point version
ystaticy Mar 6, 2024
6d2adcf
add check safe point version
ystaticy Mar 6, 2024
de5cdd1
update pd client
ystaticy Mar 7, 2024
65e2a3d
update bazel_prepare
ystaticy Mar 7, 2024
b18467b
update bazel_prepare
ystaticy Mar 7, 2024
886eddb
code format
ystaticy Mar 7, 2024
2fdfa83
code format
ystaticy Mar 7, 2024
a2c73a5
fix ut
ystaticy Mar 7, 2024
758b32b
fix ut
ystaticy Mar 7, 2024
42110ef
code format
ystaticy Mar 8, 2024
6869584
code format
ystaticy Mar 11, 2024
0d1bbea
merge master
ystaticy Mar 11, 2024
00ef880
merge master
ystaticy Mar 28, 2024
6fd972d
change func name
ystaticy Mar 29, 2024
505b1c8
code format
ystaticy Mar 29, 2024
61500f1
fix funcs name
ystaticy Apr 1, 2024
81a8e24
fix funcs name
ystaticy Apr 1, 2024
6398461
fix start tidb enable ks level gc
ystaticy Apr 3, 2024
ff47e2f
remove unused dir
ystaticy Apr 3, 2024
497a2c2
add tidb config check
ystaticy Apr 3, 2024
7c89b76
updage error info
ystaticy Apr 3, 2024
7d2a32f
code format
ystaticy Apr 3, 2024
acb8012
merge master
ystaticy Apr 3, 2024
bc2c6ca
fix bazel_build
ystaticy Apr 3, 2024
12870d3
code format
ystaticy Apr 3, 2024
4752f82
code format
ystaticy Apr 3, 2024
d18062a
Merge branch 'master' into tidb_gc_v2
ystaticy Apr 3, 2024
57b6b94
go mod tidy
ystaticy Apr 3, 2024
2370ab1
code format
ystaticy Apr 3, 2024
55b889a
code format
ystaticy Apr 14, 2024
129c937
code format
ystaticy Apr 14, 2024
60f61a2
fix variable name
ystaticy Apr 17, 2024
9990d10
fix comments
ystaticy Apr 18, 2024
ba4271a
add condition
ystaticy Apr 18, 2024
0a7cca4
fix default const
ystaticy Apr 18, 2024
dc591e0
fix code format
ystaticy Apr 21, 2024
73fab6e
fix code format
ystaticy Apr 21, 2024
a1f4c86
fix func name
ystaticy Apr 21, 2024
71b7b1b
fix code comments
ystaticy Apr 21, 2024
c9d9c7d
fix ut
ystaticy Apr 22, 2024
6758c62
fix ut
ystaticy Apr 22, 2024
a26c6f8
fix ut
ystaticy Apr 22, 2024
86d1f6a
fix check
ystaticy Apr 22, 2024
5192a05
fix code comments
ystaticy Apr 22, 2024
173be3d
fix code format
ystaticy Apr 23, 2024
0d55733
fix code comments
ystaticy Apr 23, 2024
fe412c5
fix bazel
ystaticy Apr 23, 2024
9de2764
fix code format
ystaticy Apr 23, 2024
ca7ac7e
fix code format
ystaticy Apr 23, 2024
e28001d
Merge remote-tracking branch 'origin/master' into tidb_gc_v2
ystaticy Apr 23, 2024
d97535e
fix code format
ystaticy Apr 23, 2024
87cf0a3
fix code format
ystaticy Apr 23, 2024
7644a47
fix code format
ystaticy Apr 23, 2024
19fb2cd
fix dir
ystaticy Apr 23, 2024
0db54f8
fix init
ystaticy Apr 23, 2024
335ad17
fix resolve locks
ystaticy Apr 23, 2024
6b1d431
fix init keyspace
ystaticy Apr 26, 2024
4717886
use get keysapce meta
ystaticy Apr 28, 2024
cd1808e
fix code comments
ystaticy Apr 28, 2024
a3ad336
fix get ks meta func
ystaticy Apr 28, 2024
06aed90
fix get ks meta func
ystaticy Apr 28, 2024
25f18b5
fix import
ystaticy Apr 28, 2024
9c0ebac
fix import
ystaticy Apr 28, 2024
7f5eb71
fix comments
ystaticy Apr 28, 2024
baeca73
fix comments
ystaticy Apr 28, 2024
c7e7422
fix comments
ystaticy Apr 28, 2024
51f7fc1
merge master
ystaticy Apr 28, 2024
03411c3
fix bazel
ystaticy Apr 29, 2024
73d9703
make bazel_prepare
ystaticy Apr 29, 2024
93bcfd6
fix format
ystaticy Apr 29, 2024
0fc78c9
fix ut
ystaticy Apr 29, 2024
07efad1
fix ut
ystaticy Apr 29, 2024
839cfb6
Merge remote-tracking branch 'origin/master' into tidb_gc_v2
ystaticy Apr 29, 2024
5452256
fix log
ystaticy Apr 29, 2024
759b6c5
rm bazel temp dir
ystaticy Apr 29, 2024
00b9d1f
fix log
ystaticy Apr 29, 2024
6388fe3
merge master
ystaticy Apr 29, 2024
0bbd3bd
fix resolve ks locks
ystaticy Apr 29, 2024
c058f14
fix logs, code comments
ystaticy Apr 30, 2024
43067d8
fix resolve locks
ystaticy Apr 30, 2024
b77dc94
rm bazel temp dir
ystaticy Apr 30, 2024
e4b8aaf
fix get ks id
ystaticy Apr 30, 2024
095c04e
fix const
ystaticy Apr 30, 2024
990d73b
fix code comments and logs
ystaticy May 6, 2024
c9af2d3
Unified get maxKeyspaceIDTxnRightBound
ystaticy May 6, 2024
a4c786c
fix comments
ystaticy May 6, 2024
71684e0
fix func name
ystaticy May 6, 2024
5990e54
fix func name
ystaticy May 6, 2024
1deef97
fix log
ystaticy May 6, 2024
10919f9
fix func name
ystaticy May 6, 2024
2a3f820
fix func name
ystaticy May 6, 2024
c543d86
fix comments
ystaticy May 6, 2024
b53ce1b
merge master
ystaticy Oct 27, 2024
a29b940
Merge branch 'master' into tidb_gc_v2
ystaticy Nov 27, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 1 addition & 0 deletions pkg/domain/infosync/BUILD.bazel
Original file line number Diff line number Diff line change
Expand Up @@ -21,6 +21,7 @@ go_library(
"//pkg/ddl/placement",
"//pkg/ddl/util",
"//pkg/errno",
"//pkg/keyspace",
"//pkg/kv",
"//pkg/meta/model",
"//pkg/metrics",
Expand Down
18 changes: 16 additions & 2 deletions pkg/domain/infosync/info.go
Original file line number Diff line number Diff line change
Expand Up @@ -38,6 +38,7 @@ import (
"github.com/pingcap/tidb/pkg/ddl/placement"
"github.com/pingcap/tidb/pkg/ddl/util"
"github.com/pingcap/tidb/pkg/errno"
"github.com/pingcap/tidb/pkg/keyspace"
"github.com/pingcap/tidb/pkg/kv"
"github.com/pingcap/tidb/pkg/meta/model"
"github.com/pingcap/tidb/pkg/metrics"
Expand Down Expand Up @@ -126,6 +127,7 @@ type InfoSyncer struct {
scheduleManager ScheduleManager
tiflashReplicaManager TiFlashReplicaManager
resourceManagerClient pd.ResourceManagerClient
tikvCodec tikv.Codec
}

// ServerInfo is server static information.
Expand Down Expand Up @@ -224,6 +226,7 @@ func GlobalInfoSyncerInit(
info: getServerInfo(id, serverIDGetter),
serverInfoPath: fmt.Sprintf("%s/%s", ServerInformationPath, id),
minStartTSPath: fmt.Sprintf("%s/%s", ServerMinStartTSPath, id),
tikvCodec: codec,
}
err := is.init(ctx, skipRegisterToDashBoard)
if err != nil {
Expand Down Expand Up @@ -734,12 +737,23 @@ func (is *InfoSyncer) GetMinStartTS() uint64 {
return is.minStartTS
}

func (is *InfoSyncer) getMinStartTsEtcdCli() *clientv3.Client {
if keyspace.IsKeyspaceUseKeyspaceLevelGC(is.tikvCodec.GetKeyspaceMeta()) {
// If the current keyspace uses keyspace level GC,
// we should use the etcd namespace with the keyspace prefix
// to access the etcd key for min start timestamp of the current keyspace.
return is.etcdCli
}
return is.unprefixedEtcdCli
}

// storeMinStartTS stores self server min start timestamp to etcd.
func (is *InfoSyncer) storeMinStartTS(ctx context.Context) error {
if is.unprefixedEtcdCli == nil {
minStartTsEtcdCli := is.getMinStartTsEtcdCli()
if minStartTsEtcdCli == nil {
return nil
}
return util.PutKVToEtcd(ctx, is.unprefixedEtcdCli, keyOpDefaultRetryCnt, is.minStartTSPath,
return util.PutKVToEtcd(ctx, minStartTsEtcdCli, keyOpDefaultRetryCnt, is.minStartTSPath,
ystaticy marked this conversation as resolved.
Show resolved Hide resolved
strconv.FormatUint(is.minStartTS, 10),
clientv3.WithLease(is.session.Lease()))
}
Expand Down
5 changes: 5 additions & 0 deletions pkg/keyspace/BUILD.bazel
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,8 @@ go_library(
visibility = ["//visibility:public"],
deps = [
"//pkg/config",
"//pkg/util/codec",
"@com_github_pingcap_kvproto//pkg/keyspacepb",
"@com_github_pingcap_kvproto//pkg/kvrpcpb",
"@com_github_tikv_client_go_v2//tikv",
"@org_uber_go_zap//:zap",
Expand All @@ -20,8 +22,11 @@ go_test(
srcs = ["keyspace_test.go"],
embed = [":keyspace"],
flaky = True,
shard_count = 4,
deps = [
"//pkg/config",
"//pkg/util/codec",
"@com_github_pingcap_kvproto//pkg/keyspacepb",
"@com_github_stretchr_testify//require",
],
)
79 changes: 78 additions & 1 deletion pkg/keyspace/keyspace.go
Original file line number Diff line number Diff line change
Expand Up @@ -15,10 +15,13 @@
package keyspace

import (
"encoding/binary"
"fmt"

"github.com/pingcap/kvproto/pkg/keyspacepb"
"github.com/pingcap/kvproto/pkg/kvrpcpb"
"github.com/pingcap/tidb/pkg/config"
"github.com/pingcap/tidb/pkg/util/codec"
"github.com/tikv/client-go/v2/tikv"
"go.uber.org/zap"
"go.uber.org/zap/zapcore"
Expand All @@ -27,6 +30,30 @@ import (
const (
// tidbKeyspaceEtcdPathPrefix is the keyspace prefix for etcd namespace
tidbKeyspaceEtcdPathPrefix = "/keyspaces/tidb/"

// KeyspaceMetaConfigGCManagementType is the name of the key for GC management type in keyspace meta config.
KeyspaceMetaConfigGCManagementType = "gc_management_type"
Copy link
Contributor Author

@ystaticy ystaticy Apr 22, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Must set KeyspaceMetaConfigGCManagementType and KeyspaceMetaConfigGCManagementTypeKeyspaceLevelGC here, to fix import cycle.

// KeyspaceMetaConfigGCManagementTypeKeyspaceLevelGC is a type of GC management in keyspace meta config,
// it means this keyspace will calculate GC safe point by its own.
KeyspaceMetaConfigGCManagementTypeKeyspaceLevelGC = "keyspace_level_gc"
// KeyspaceMetaConfigGCManagementTypeGlobalGC is a type of GC management in keyspace meta config, it means this keyspace will use GC safe point by global GC(default).
KeyspaceMetaConfigGCManagementTypeGlobalGC = "global_gc"

// maxKeyspaceID is the maximum keyspace id that can be created, no keyspace can be created greater than this value.
maxKeyspaceID = 0xffffff

// API V2 key bounds:
// See https://github.com/tikv/rfcs/blob/master/text/0069-api-v2.md for more keyspace and API V2 details.

// KeyspaceTxnModePrefix is txn data prefix of keyspace.
KeyspaceTxnModePrefix byte = 'x'
// MaxKeyspaceRightBoundaryPrefix is the max keyspace txn right boundary.
// Because the keyspace ranges are all under the 'x' prefix, so MaxKeyspaceRightBoundaryPrefix = 'y'
MaxKeyspaceRightBoundaryPrefix byte = 'y'
// RawKVLeftBoundaryPrefix is RawKV left boundary.
RawKVLeftBoundaryPrefix byte = 'r'
// RawKVRightBoundaryPrefix is RawKV right boundary.
RawKVRightBoundaryPrefix byte = 's'
)

// CodecV1 represents api v1 codec.
Expand All @@ -40,7 +67,7 @@ func MakeKeyspaceEtcdNamespace(c tikv.Codec) string {
return fmt.Sprintf(tidbKeyspaceEtcdPathPrefix+"%d", c.GetKeyspaceID())
}

// MakeKeyspaceEtcdNamespaceSlash return the keyspace prefix path for etcd namespace, and end with a slash.
// MakeKeyspaceEtcdNamespaceSlash returns the keyspace prefix path for etcd namespace, and end with a slash.
func MakeKeyspaceEtcdNamespaceSlash(c tikv.Codec) string {
if c.GetAPIVersion() == kvrpcpb.APIVersion_V1 {
return ""
Expand Down Expand Up @@ -69,3 +96,53 @@ func WrapZapcoreWithKeyspace() zap.Option {
return core
})
}

// IsKeyspaceUseKeyspaceLevelGC returns true if keyspace meta config set "gc_management_type" = "keyspace_level_gc" explicitly.
func IsKeyspaceUseKeyspaceLevelGC(keyspaceMeta *keyspacepb.KeyspaceMeta) bool {
if keyspaceMeta == nil {
return false
}
if val, ok := keyspaceMeta.Config[KeyspaceMetaConfigGCManagementType]; ok {
return val == KeyspaceMetaConfigGCManagementTypeKeyspaceLevelGC
}
return false
}

// IsKeyspaceMetaNotNilAndUseGlobalGC returns whether the specified keyspace meta use global GC.
func IsKeyspaceMetaNotNilAndUseGlobalGC(keyspaceMeta *keyspacepb.KeyspaceMeta) bool {
if keyspaceMeta == nil {
return false
}
if val, ok := keyspaceMeta.Config[KeyspaceMetaConfigGCManagementType]; ok {
return val == KeyspaceMetaConfigGCManagementTypeGlobalGC
}
return true
}

// GetKeyspaceTxnLeftBound returns the specified keyspace txn left boundary.
func GetKeyspaceTxnLeftBound(keyspaceID uint32) []byte {
keyspaceIDBytes := make([]byte, 4)
binary.BigEndian.PutUint32(keyspaceIDBytes, keyspaceID)

// The first byte is keyspaceTxnModePrefix, and the next three bytes are converted from uint32
txnLeftBound := codec.EncodeBytes(nil, append([]byte{KeyspaceTxnModePrefix}, keyspaceIDBytes[1:]...))
return txnLeftBound
}

// GetKeyspaceTxnRange returns the specified keyspace txn left boundary and txn right boundary.
func GetKeyspaceTxnRange(keyspaceID uint32) ([]byte, []byte) {
// Get keyspace txn left boundary
txnLeftBound := GetKeyspaceTxnLeftBound(keyspaceID)

var txnRightBound []byte
if keyspaceID == maxKeyspaceID {
// Directly set the right boundary of maxKeyspaceID to be {MaxKeyspaceRightBoundaryPrefix}
maxKeyspaceIDTxnRightBound := []byte{MaxKeyspaceRightBoundaryPrefix}
txnRightBound = codec.EncodeBytes(nil, maxKeyspaceIDTxnRightBound[:])
} else {
// The right boundary of the specified keyspace is the left boundary of keyspaceID + 1.
txnRightBound = GetKeyspaceTxnLeftBound(keyspaceID + 1)
}

return txnLeftBound, txnRightBound
}
57 changes: 57 additions & 0 deletions pkg/keyspace/keyspace_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,9 @@ package keyspace
import (
"testing"

"github.com/pingcap/kvproto/pkg/keyspacepb"
"github.com/pingcap/tidb/pkg/config"
"github.com/pingcap/tidb/pkg/util/codec"
"github.com/stretchr/testify/require"
)

Expand Down Expand Up @@ -50,3 +52,58 @@ func TestNoKeyspaceNameSet(t *testing.T) {
require.Equal(t, "", getKeyspaceName)
require.Equal(t, true, IsKeyspaceNameEmpty(getKeyspaceName))
}

func TestGetKeyspaceRange(t *testing.T) {
keyspaceID := uint32(1)
leftBound, rightBound := GetKeyspaceTxnRange(keyspaceID)
expectLeftBound := codec.EncodeBytes(nil, []byte{'x', 0, 0, 1})
expectRightBound := codec.EncodeBytes(nil, []byte{'x', 0, 0, 2})
require.Equal(t, expectLeftBound, leftBound)
require.Equal(t, expectRightBound, rightBound)

// Check the max keyspace ID txn left boundary and txn right boundary.
maxKeyspaceIDLeftBound, maxKeyspaceIDRightBound := GetKeyspaceTxnRange(maxKeyspaceID)
expectMaxKeyspaceIDLeftBound := codec.EncodeBytes(nil, []byte{'x', 0xff, 0xff, 0xff})
maxKeyspaceIDexpectRightBound := codec.EncodeBytes(nil, []byte{MaxKeyspaceRightBoundaryPrefix})
require.Equal(t, expectMaxKeyspaceIDLeftBound, maxKeyspaceIDLeftBound)
require.Equal(t, maxKeyspaceIDexpectRightBound, maxKeyspaceIDRightBound)
}

func TestGetKeyspaceGCManagementType(t *testing.T) {
// Case 1: The keyspace use global GC by default.
keyspaceMeta := keyspacepb.KeyspaceMeta{
Id: 1,
}

require.Equal(t, false, IsKeyspaceUseKeyspaceLevelGC(&keyspaceMeta))
require.Equal(t, true, IsKeyspaceMetaNotNilAndUseGlobalGC(&keyspaceMeta))

// Case 2: The keyspace is set to use global GC.
keyspaceConfig := map[string]string{
KeyspaceMetaConfigGCManagementType: KeyspaceMetaConfigGCManagementTypeGlobalGC,
}
keyspaceMeta = keyspacepb.KeyspaceMeta{
Id: 1,
Config: keyspaceConfig,
}

require.Equal(t, false, IsKeyspaceUseKeyspaceLevelGC(&keyspaceMeta))
require.Equal(t, true, IsKeyspaceMetaNotNilAndUseGlobalGC(&keyspaceMeta))

// Case 3: The keyspace is set to use keyspace level GC.
keyspaceConfig = map[string]string{
KeyspaceMetaConfigGCManagementType: KeyspaceMetaConfigGCManagementTypeKeyspaceLevelGC,
}
keyspaceMeta = keyspacepb.KeyspaceMeta{
Id: 1,
Config: keyspaceConfig,
}
require.Equal(t, true, IsKeyspaceUseKeyspaceLevelGC(&keyspaceMeta))
require.Equal(t, false, IsKeyspaceMetaNotNilAndUseGlobalGC(&keyspaceMeta))

// Case 4: The keyspace meta is nil, it doesn't use keyspace level GC.
require.Equal(t, false, IsKeyspaceUseKeyspaceLevelGC(nil))

// Case 5: The keyspace meta is nil, IsKeyspaceMetaNotNilAndUseGlobalGC will return false.
require.Equal(t, false, IsKeyspaceMetaNotNilAndUseGlobalGC(nil))
}
4 changes: 4 additions & 0 deletions pkg/kv/interface_mock_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -197,6 +197,10 @@ func newMockTxn() Transaction {
// mockStorage is used to start a must commit-failed txn.
type mockStorage struct{}

func (s *mockStorage) CurrentAllTSOKeyspaceGroupMinTs() (uint64, error) {
return 0, nil
}

func (s *mockStorage) GetOption(k any) (any, bool) {
return nil, false
}
Expand Down
2 changes: 2 additions & 0 deletions pkg/kv/kv.go
Original file line number Diff line number Diff line change
Expand Up @@ -703,6 +703,8 @@ type Storage interface {
UUID() string
// CurrentVersion returns current max committed version with the given txnScope (local or global).
CurrentVersion(txnScope string) (Version, error)
// CurrentAllTSOKeyspaceGroupMinTs returns current minimum ts from all TSO keyspace groups.
CurrentAllTSOKeyspaceGroupMinTs() (uint64, error)
// GetOracle gets a timestamp oracle client.
GetOracle() oracle.Oracle
// SupportDeleteRange gets the storage support delete range or not.
Expand Down
1 change: 1 addition & 0 deletions pkg/store/driver/BUILD.bazel
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,7 @@ go_library(
importpath = "github.com/pingcap/tidb/pkg/store/driver",
visibility = ["//visibility:public"],
deps = [
"//pkg/keyspace",
"//pkg/kv",
"//pkg/metrics",
"//pkg/sessionctx/variable",
Expand Down
27 changes: 22 additions & 5 deletions pkg/store/driver/tikv_driver.go
Original file line number Diff line number Diff line change
Expand Up @@ -27,6 +27,7 @@ import (
"github.com/pingcap/errors"
deadlockpb "github.com/pingcap/kvproto/pkg/deadlock"
"github.com/pingcap/kvproto/pkg/kvrpcpb"
"github.com/pingcap/tidb/pkg/keyspace"
"github.com/pingcap/tidb/pkg/kv"
"github.com/pingcap/tidb/pkg/metrics"
"github.com/pingcap/tidb/pkg/sessionctx/variable"
Expand Down Expand Up @@ -122,6 +123,16 @@ func (d *TiKVDriver) setDefaultAndOptions(options ...Option) {
}
}

// NewEtcdSafePointKVWithKeyspacePrefixIfNeeded is used to add etcd namespace with keyspace prefix,
// if the current keyspace use keyspace level GC.
func NewEtcdSafePointKVWithKeyspacePrefixIfNeeded(etcdAddrs []string, codec tikv.Codec, tlsConfig *tls.Config) (*tikv.EtcdSafePointKV, error) {
var etcdNameSpace string
if keyspace.IsKeyspaceUseKeyspaceLevelGC(codec.GetKeyspaceMeta()) {
etcdNameSpace = keyspace.MakeKeyspaceEtcdNamespace(codec)
}
return tikv.NewEtcdSafePointKV(etcdAddrs, tlsConfig, tikv.WithPrefix(etcdNameSpace))
}

// OpenWithOptions is used by other program that use tidb as a library, to avoid modifying GlobalConfig
// unspecified options will be set to global config
func (d TiKVDriver) OpenWithOptions(path string, options ...Option) (resStore kv.Storage, err error) {
Expand Down Expand Up @@ -187,11 +198,6 @@ func (d TiKVDriver) OpenWithOptions(path string, options ...Option) (resStore kv
return nil, errors.Trace(err)
}

spkv, err = tikv.NewEtcdSafePointKV(etcdAddrs, tlsConfig)
if err != nil {
return nil, errors.Trace(err)
}

// ---------------- keyspace logic ----------------
var (
pdClient *tikv.CodecPDClient
Expand All @@ -215,6 +221,11 @@ func (d TiKVDriver) OpenWithOptions(path string, options ...Option) (resStore kv
tikv.WithCodec(codec),
)

spkv, err = NewEtcdSafePointKVWithKeyspacePrefixIfNeeded(etcdAddrs, codec, tlsConfig)
if err != nil {
return nil, errors.Trace(err)
}

s, err = tikv.NewKVStore(uuid, pdClient, spkv, &injectTraceClient{Client: rpcClient},
tikv.WithPDHTTPClient("tikv-driver", etcdAddrs, pdhttp.WithTLSConfig(tlsConfig), pdhttp.WithMetrics(metrics.PDAPIRequestCounter, metrics.PDAPIExecutionHistogram)))
if err != nil {
Expand Down Expand Up @@ -395,6 +406,12 @@ func (s *tikvStore) CurrentVersion(txnScope string) (kv.Version, error) {
return kv.NewVersion(ver), derr.ToTiDBErr(err)
}

// CurrentAllTSOKeyspaceGroupMinTs returns a minimum timestamp from all TSO keyspace groups.
func (s *tikvStore) CurrentAllTSOKeyspaceGroupMinTs() (uint64, error) {
ts, err := s.KVStore.CurrentAllTSOKeyspaceGroupMinTs()
return ts, derr.ToTiDBErr(err)
}

// ShowStatus returns the specified status of the storage
func (s *tikvStore) ShowStatus(ctx context.Context, key string) (any, error) {
return nil, kv.ErrNotImplemented
Expand Down
2 changes: 2 additions & 0 deletions pkg/store/gcworker/BUILD.bazel
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,7 @@ go_library(
"//pkg/ddl/placement",
"//pkg/ddl/util",
"//pkg/domain/infosync",
"//pkg/keyspace",
"//pkg/kv",
"//pkg/meta/model",
"//pkg/metrics",
Expand All @@ -27,6 +28,7 @@ go_library(
"@com_github_pingcap_errors//:errors",
"@com_github_pingcap_failpoint//:failpoint",
"@com_github_pingcap_kvproto//pkg/errorpb",
"@com_github_pingcap_kvproto//pkg/keyspacepb",
"@com_github_pingcap_kvproto//pkg/kvrpcpb",
"@com_github_pingcap_kvproto//pkg/metapb",
"@com_github_tikv_client_go_v2//error",
Expand Down
Loading