From 68d4daf6ca2166e6bd1d37c1332b311b754d6a7b Mon Sep 17 00:00:00 2001 From: ajwerner Date: Wed, 8 Mar 2023 10:51:27 -0500 Subject: [PATCH] sql,clusterversion,gc_job: hoist version gates for DelRange to 23.1 We added version gates to unconditionally enable sending DelRange tombstones in 22.2, but then we pre-empted that by disabling them with a cluster setting. This PR hoists those gates and that invariant checking up to 23.1. Relates to #96763 Release note: None --- .../settings/settings-for-tenants.txt | 2 +- docs/generated/settings/settings.html | 2 +- pkg/cli/testdata/declarative-rules/deprules | 2 +- pkg/cli/testdata/declarative-rules/oprules | 2 +- pkg/clusterversion/cockroach_versions.go | 38 ++++++++++--------- pkg/sql/gcjob/BUILD.bazel | 1 - pkg/sql/gcjob/gc_job.go | 2 - pkg/sql/gcjob/gcjobnotifier/notifier.go | 2 +- pkg/sql/repair.go | 4 +- pkg/sql/schema_changer.go | 11 +++--- pkg/sql/schemachanger/scdeps/BUILD.bazel | 2 +- pkg/sql/schemachanger/scdeps/exec_deps.go | 4 +- pkg/sql/schemachanger/screl/scalars.go | 2 +- pkg/sql/truncate.go | 6 +-- pkg/upgrade/upgrades/upgrades.go | 10 ++--- .../wait_for_del_range_in_gc_job_test.go | 8 ++-- 16 files changed, 46 insertions(+), 52 deletions(-) diff --git a/docs/generated/settings/settings-for-tenants.txt b/docs/generated/settings/settings-for-tenants.txt index a72454410acc..cee0b1797600 100644 --- a/docs/generated/settings/settings-for-tenants.txt +++ b/docs/generated/settings/settings-for-tenants.txt @@ -299,4 +299,4 @@ trace.opentelemetry.collector string address of an OpenTelemetry trace collecto trace.snapshot.rate duration 0s if non-zero, interval at which background trace snapshots are captured trace.span_registry.enabled boolean true if set, ongoing traces can be seen at https:///#/debug/tracez trace.zipkin.collector string the address of a Zipkin instance to receive traces, as :. If no port is specified, 9411 will be used. -version version 1000022.2-80 set the active cluster version in the format '.' +version version 1000022.2-84 set the active cluster version in the format '.' diff --git a/docs/generated/settings/settings.html b/docs/generated/settings/settings.html index 1aa4da7f7e7e..a505d318e501 100644 --- a/docs/generated/settings/settings.html +++ b/docs/generated/settings/settings.html @@ -240,6 +240,6 @@
trace.snapshot.rate
duration0sif non-zero, interval at which background trace snapshots are captured
trace.span_registry.enabled
booleantrueif set, ongoing traces can be seen at https://<ui>/#/debug/tracez
trace.zipkin.collector
stringthe address of a Zipkin instance to receive traces, as <host>:<port>. If no port is specified, 9411 will be used. -
version
version1000022.2-80set the active cluster version in the format '<major>.<minor>' +
version
version1000022.2-84set the active cluster version in the format '<major>.<minor>' diff --git a/pkg/cli/testdata/declarative-rules/deprules b/pkg/cli/testdata/declarative-rules/deprules index c9e4be873845..be21ca55288a 100644 --- a/pkg/cli/testdata/declarative-rules/deprules +++ b/pkg/cli/testdata/declarative-rules/deprules @@ -1,6 +1,6 @@ dep ---- -debug declarative-print-rules 1000022.2-80 dep +debug declarative-print-rules 1000022.2-84 dep deprules ---- - name: 'CheckConstraint transitions to ABSENT uphold 2-version invariant: PUBLIC->VALIDATED' diff --git a/pkg/cli/testdata/declarative-rules/oprules b/pkg/cli/testdata/declarative-rules/oprules index 01262e55df2f..b88210dffbbc 100644 --- a/pkg/cli/testdata/declarative-rules/oprules +++ b/pkg/cli/testdata/declarative-rules/oprules @@ -1,6 +1,6 @@ op ---- -debug declarative-print-rules 1000022.2-80 op +debug declarative-print-rules 1000022.2-84 op rules ---- [] diff --git a/pkg/clusterversion/cockroach_versions.go b/pkg/clusterversion/cockroach_versions.go index a7529e5aa7e7..76fedfff9f32 100644 --- a/pkg/clusterversion/cockroach_versions.go +++ b/pkg/clusterversion/cockroach_versions.go @@ -252,16 +252,6 @@ const ( // options table id column cannot be null. This is the final step // of the system.role_options table migration. TODODelete_V22_2SetRoleOptionsUserIDColumnNotNull - // TODODelete_V22_2UseDelRangeInGCJob enables the use of the DelRange operation in the - // GC job. Before it is enabled, the GC job uses ClearRange operations - // after the job waits out the GC TTL. After it has been enabled, the - // job instead issues DelRange operations at the beginning of the job - // and then waits for the data to be removed automatically before removing - // the descriptor and zone configurations. - TODODelete_V22_2UseDelRangeInGCJob - // TODODelete_V22_2WaitedForDelRangeInGCJob corresponds to the migration which waits for - // the GC jobs to adopt the use of DelRange with tombstones. - TODODelete_V22_2WaitedForDelRangeInGCJob // TODODelete_V22_2RangefeedUseOneStreamPerNode changes rangefeed implementation to use 1 RPC stream per node. TODODelete_V22_2RangefeedUseOneStreamPerNode // TODODelete_V22_2NoNonMVCCAddSSTable adds a migration which waits for all @@ -484,6 +474,18 @@ const ( // progress of each job in the system.jobs table. V23_1JobInfoTableIsBackfilled + // V23_1_UseDelRangeInGCJob enables the use of the DelRange operation in the + // GC job. Before it is enabled, the GC job uses ClearRange operations + // after the job waits out the GC TTL. After it has been enabled, the + // job instead issues DelRange operations at the beginning of the job + // and then waits for the data to be removed automatically before removing + // the descriptor and zone configurations. + V23_1_UseDelRangeInGCJob + + // V23_1WaitedForDelRangeInGCJob corresponds to the migration which waits for + // the GC jobs to adopt the use of DelRange with tombstones. + V23_1WaitedForDelRangeInGCJob + // ************************************************* // Step (1): Add new versions here. // Do not add new versions to a patch release. @@ -637,14 +639,6 @@ var rawVersionsSingleton = keyedVersions{ Key: TODODelete_V22_2SetRoleOptionsUserIDColumnNotNull, Version: roachpb.Version{Major: 22, Minor: 1, Internal: 54}, }, - { - Key: TODODelete_V22_2UseDelRangeInGCJob, - Version: roachpb.Version{Major: 22, Minor: 1, Internal: 56}, - }, - { - Key: TODODelete_V22_2WaitedForDelRangeInGCJob, - Version: roachpb.Version{Major: 22, Minor: 1, Internal: 58}, - }, { Key: TODODelete_V22_2RangefeedUseOneStreamPerNode, Version: roachpb.Version{Major: 22, Minor: 1, Internal: 60}, @@ -837,6 +831,14 @@ var rawVersionsSingleton = keyedVersions{ Key: V23_1JobInfoTableIsBackfilled, Version: roachpb.Version{Major: 22, Minor: 2, Internal: 80}, }, + { + Key: V23_1_UseDelRangeInGCJob, + Version: roachpb.Version{Major: 22, Minor: 2, Internal: 82}, + }, + { + Key: V23_1WaitedForDelRangeInGCJob, + Version: roachpb.Version{Major: 22, Minor: 2, Internal: 84}, + }, // ************************************************* // Step (2): Add new versions here. diff --git a/pkg/sql/gcjob/BUILD.bazel b/pkg/sql/gcjob/BUILD.bazel index 112f92de88b5..c70fbcb350e9 100644 --- a/pkg/sql/gcjob/BUILD.bazel +++ b/pkg/sql/gcjob/BUILD.bazel @@ -16,7 +16,6 @@ go_library( importpath = "github.com/cockroachdb/cockroach/pkg/sql/gcjob", visibility = ["//visibility:public"], deps = [ - "//pkg/clusterversion", "//pkg/config", "//pkg/config/zonepb", "//pkg/jobs", diff --git a/pkg/sql/gcjob/gc_job.go b/pkg/sql/gcjob/gc_job.go index 6c30ad8474f5..8e5fdee0c36b 100644 --- a/pkg/sql/gcjob/gc_job.go +++ b/pkg/sql/gcjob/gc_job.go @@ -15,7 +15,6 @@ import ( "strings" "time" - "github.com/cockroachdb/cockroach/pkg/clusterversion" "github.com/cockroachdb/cockroach/pkg/jobs" "github.com/cockroachdb/cockroach/pkg/jobs/jobspb" "github.com/cockroachdb/cockroach/pkg/kv" @@ -508,7 +507,6 @@ func shouldUseDelRange( ) bool { // TODO(ajwerner): Adopt the DeleteRange protocol for tenant GC. return details.Tenant == nil && - s.Version.IsActive(ctx, clusterversion.TODODelete_V22_2UseDelRangeInGCJob) && (storage.CanUseMVCCRangeTombstones(ctx, s) || // Allow this testing knob to override the storage setting, for convenience. knobs.SkipWaitingForMVCCGC) diff --git a/pkg/sql/gcjob/gcjobnotifier/notifier.go b/pkg/sql/gcjob/gcjobnotifier/notifier.go index 55af1757ef2f..30a3590220b8 100644 --- a/pkg/sql/gcjob/gcjobnotifier/notifier.go +++ b/pkg/sql/gcjob/gcjobnotifier/notifier.go @@ -147,7 +147,7 @@ func (n *Notifier) run(_ context.Context) { systemConfigUpdateCh, _ := n.provider.RegisterSystemConfigChannel() var haveNotified syncutil.AtomicBool versionSettingChanged := make(chan struct{}, 1) - versionBeingWaited := clusterversion.ByKey(clusterversion.TODODelete_V22_2UseDelRangeInGCJob) + versionBeingWaited := clusterversion.ByKey(clusterversion.V23_1_UseDelRangeInGCJob) n.settings.Version.SetOnChange(func(ctx context.Context, newVersion clusterversion.ClusterVersion) { if !haveNotified.Get() && versionBeingWaited.LessEq(newVersion.Version) && diff --git a/pkg/sql/repair.go b/pkg/sql/repair.go index 30d1ea2652e6..3dd160112205 100644 --- a/pkg/sql/repair.go +++ b/pkg/sql/repair.go @@ -18,7 +18,6 @@ import ( "time" "github.com/cockroachdb/cockroach/pkg/cloud" - "github.com/cockroachdb/cockroach/pkg/clusterversion" "github.com/cockroachdb/cockroach/pkg/config/zonepb" "github.com/cockroachdb/cockroach/pkg/keys" "github.com/cockroachdb/cockroach/pkg/kv" @@ -742,8 +741,7 @@ func (p *planner) ForceDeleteTableData(ctx context.Context, descID int64) error Key: tableSpan.Key, EndKey: tableSpan.EndKey, } b := &kv.Batch{} - if p.execCfg.Settings.Version.IsActive(ctx, clusterversion.TODODelete_V22_2UseDelRangeInGCJob) && - storage.CanUseMVCCRangeTombstones(ctx, p.execCfg.Settings) { + if storage.CanUseMVCCRangeTombstones(ctx, p.execCfg.Settings) { b.AddRawRequest(&kvpb.DeleteRangeRequest{ RequestHeader: requestHeader, UseRangeTombstone: true, diff --git a/pkg/sql/schema_changer.go b/pkg/sql/schema_changer.go index 18be6425abba..c94444ed7373 100644 --- a/pkg/sql/schema_changer.go +++ b/pkg/sql/schema_changer.go @@ -55,6 +55,7 @@ import ( "github.com/cockroachdb/cockroach/pkg/sql/sessiondatapb" "github.com/cockroachdb/cockroach/pkg/sql/sqlerrors" "github.com/cockroachdb/cockroach/pkg/sql/sqltelemetry" + "github.com/cockroachdb/cockroach/pkg/storage" "github.com/cockroachdb/cockroach/pkg/util/grpcutil" "github.com/cockroachdb/cockroach/pkg/util/hlc" "github.com/cockroachdb/cockroach/pkg/util/log" @@ -738,7 +739,7 @@ func (sc *SchemaChanger) exec(ctx context.Context) error { sc.job.Payload().UsernameProto.Decode(), sc.job.Payload().Description, gcDetails, - !sc.settings.Version.IsActive(ctx, clusterversion.TODODelete_V22_2UseDelRangeInGCJob), + !storage.CanUseMVCCRangeTombstones(ctx, sc.settings), ); err != nil { return err } @@ -1074,7 +1075,7 @@ func (sc *SchemaChanger) rollbackSchemaChange(ctx context.Context, err error) er }, }, }, - !sc.settings.Version.IsActive(ctx, clusterversion.TODODelete_V22_2UseDelRangeInGCJob), + !storage.CanUseMVCCRangeTombstones(ctx, sc.settings), ) if _, err := sc.jobRegistry.CreateJobWithTxn(ctx, jobRecord, gcJobID, txn); err != nil { return err @@ -1284,7 +1285,7 @@ func (sc *SchemaChanger) createIndexGCJobWithDropTime( gcJobRecord := CreateGCJobRecord( jobDesc, sc.job.Payload().UsernameProto.Decode(), indexGCDetails, - !sc.settings.Version.IsActive(ctx, clusterversion.TODODelete_V22_2UseDelRangeInGCJob), + !sc.settings.Version.IsActive(ctx, clusterversion.V23_1_UseDelRangeInGCJob), ) jobID := sc.jobRegistry.MakeJobID() if _, err := sc.jobRegistry.CreateJobWithTxn(ctx, gcJobRecord, jobID, txn); err != nil { @@ -2761,9 +2762,7 @@ func (r schemaChangeResumer) Resume(ctx context.Context, execCtx interface{}) er r.job.Payload().UsernameProto.Decode(), r.job.Payload().Description, multiTableGCDetails, - !p.ExecCfg().Settings.Version.IsActive( - ctx, clusterversion.TODODelete_V22_2UseDelRangeInGCJob, - ), + !storage.CanUseMVCCRangeTombstones(ctx, p.ExecCfg().Settings), ); err != nil { return err } diff --git a/pkg/sql/schemachanger/scdeps/BUILD.bazel b/pkg/sql/schemachanger/scdeps/BUILD.bazel index 21f382fc1521..b58d4c152f87 100644 --- a/pkg/sql/schemachanger/scdeps/BUILD.bazel +++ b/pkg/sql/schemachanger/scdeps/BUILD.bazel @@ -12,7 +12,6 @@ go_library( importpath = "github.com/cockroachdb/cockroach/pkg/sql/schemachanger/scdeps", visibility = ["//visibility:public"], deps = [ - "//pkg/clusterversion", "//pkg/jobs", "//pkg/jobs/jobspb", "//pkg/keys", @@ -42,6 +41,7 @@ go_library( "//pkg/sql/sqlerrors", "//pkg/sql/sqltelemetry", "//pkg/sql/types", + "//pkg/storage", "//pkg/util/timeutil", "//pkg/util/uuid", "@com_github_cockroachdb_errors//:errors", diff --git a/pkg/sql/schemachanger/scdeps/exec_deps.go b/pkg/sql/schemachanger/scdeps/exec_deps.go index 2e0e7f74e446..a16c38802c2d 100644 --- a/pkg/sql/schemachanger/scdeps/exec_deps.go +++ b/pkg/sql/schemachanger/scdeps/exec_deps.go @@ -15,7 +15,6 @@ import ( "fmt" "time" - "github.com/cockroachdb/cockroach/pkg/clusterversion" "github.com/cockroachdb/cockroach/pkg/jobs" "github.com/cockroachdb/cockroach/pkg/jobs/jobspb" "github.com/cockroachdb/cockroach/pkg/keys" @@ -34,6 +33,7 @@ import ( "github.com/cockroachdb/cockroach/pkg/sql/sem/tree" "github.com/cockroachdb/cockroach/pkg/sql/sessiondata" "github.com/cockroachdb/cockroach/pkg/sql/sqltelemetry" + "github.com/cockroachdb/cockroach/pkg/storage" "github.com/cockroachdb/errors" ) @@ -253,7 +253,7 @@ func (d *txnDeps) CheckPausepoint(name string) error { } func (d *txnDeps) UseLegacyGCJob(ctx context.Context) bool { - return !d.settings.Version.IsActive(ctx, clusterversion.TODODelete_V22_2UseDelRangeInGCJob) + return !storage.CanUseMVCCRangeTombstones(ctx, d.settings) } func (d *txnDeps) SchemaChangerJobID() jobspb.JobID { diff --git a/pkg/sql/schemachanger/screl/scalars.go b/pkg/sql/schemachanger/screl/scalars.go index 80ed74867e34..2d6a37495887 100644 --- a/pkg/sql/schemachanger/screl/scalars.go +++ b/pkg/sql/schemachanger/screl/scalars.go @@ -119,7 +119,7 @@ func MinElementVersion(el scpb.Element) clusterversion.Key { case *scpb.CompositeType, *scpb.CompositeTypeAttrType, *scpb.CompositeTypeAttrName: return clusterversion.V23_1 case *scpb.IndexColumn, *scpb.EnumTypeValue, *scpb.TableZoneConfig: - return clusterversion.TODODelete_V22_2UseDelRangeInGCJob + return clusterversion.V22_2 case *scpb.DatabaseData, *scpb.TableData, *scpb.IndexData, *scpb.TablePartitioning, *scpb.Function, *scpb.FunctionName, *scpb.FunctionVolatility, *scpb.FunctionLeakProof, *scpb.FunctionNullInputBehavior, *scpb.FunctionBody, *scpb.FunctionParamDefaultExpression: diff --git a/pkg/sql/truncate.go b/pkg/sql/truncate.go index ff67bf0dd2b5..1327f06fa6c1 100644 --- a/pkg/sql/truncate.go +++ b/pkg/sql/truncate.go @@ -14,7 +14,6 @@ import ( "context" "math/rand" - "github.com/cockroachdb/cockroach/pkg/clusterversion" "github.com/cockroachdb/cockroach/pkg/jobs/jobspb" "github.com/cockroachdb/cockroach/pkg/kv" "github.com/cockroachdb/cockroach/pkg/kv/kvpb" @@ -28,6 +27,7 @@ import ( "github.com/cockroachdb/cockroach/pkg/sql/privilege" "github.com/cockroachdb/cockroach/pkg/sql/schemachanger/scerrors" "github.com/cockroachdb/cockroach/pkg/sql/sem/tree" + "github.com/cockroachdb/cockroach/pkg/storage" "github.com/cockroachdb/cockroach/pkg/util/errorutil/unimplemented" "github.com/cockroachdb/cockroach/pkg/util/log" "github.com/cockroachdb/cockroach/pkg/util/log/eventpb" @@ -257,9 +257,7 @@ func (p *planner) truncateTable(ctx context.Context, id descpb.ID, jobDesc strin } record := CreateGCJobRecord( jobDesc, p.User(), details, - !p.execCfg.Settings.Version.IsActive( - ctx, clusterversion.TODODelete_V22_2UseDelRangeInGCJob, - ), + !storage.CanUseMVCCRangeTombstones(ctx, p.execCfg.Settings), ) if _, err := p.ExecCfg().JobRegistry.CreateAdoptableJobWithTxn( ctx, record, p.ExecCfg().JobRegistry.MakeJobID(), p.InternalSQLTxn(), diff --git a/pkg/upgrade/upgrades/upgrades.go b/pkg/upgrade/upgrades/upgrades.go index 8a3c7b7d1df2..7a5be9f237da 100644 --- a/pkg/upgrade/upgrades/upgrades.go +++ b/pkg/upgrade/upgrades/upgrades.go @@ -117,11 +117,6 @@ var upgrades = []upgradebase.Upgrade{ upgrade.NoPrecondition, ensureSQLSchemaTelemetrySchedule, ), - upgrade.NewTenantUpgrade("ensure all GC jobs send DeleteRange requests", - toCV(clusterversion.TODODelete_V22_2WaitedForDelRangeInGCJob), - checkForPausedGCJobs, - waitForDelRangeInGCJob, - ), upgrade.NewTenantUpgrade( "wait for all in-flight schema changes", toCV(clusterversion.TODODelete_V22_2NoNonMVCCAddSSTable), @@ -282,6 +277,11 @@ var upgrades = []upgradebase.Upgrade{ upgrade.NoPrecondition, backfillJobInfoTable, ), + upgrade.NewTenantUpgrade("ensure all GC jobs send DeleteRange requests", + toCV(clusterversion.V23_1_UseDelRangeInGCJob), + checkForPausedGCJobs, + waitForDelRangeInGCJob, + ), } func init() { diff --git a/pkg/upgrade/upgrades/wait_for_del_range_in_gc_job_test.go b/pkg/upgrade/upgrades/wait_for_del_range_in_gc_job_test.go index 8128140256b8..f238f18045ee 100644 --- a/pkg/upgrade/upgrades/wait_for_del_range_in_gc_job_test.go +++ b/pkg/upgrade/upgrades/wait_for_del_range_in_gc_job_test.go @@ -33,14 +33,14 @@ func TestWaitForDelRangeInGCJob(t *testing.T) { defer log.Scope(t).Close(t) var ( - v0 = clusterversion.ByKey(clusterversion.TODODelete_V22_2UseDelRangeInGCJob - 1) - v1 = clusterversion.ByKey(clusterversion.TODODelete_V22_2WaitedForDelRangeInGCJob) + v0 = clusterversion.ByKey(clusterversion.V23_1_UseDelRangeInGCJob - 1) + v1 = clusterversion.ByKey(clusterversion.V23_1WaitedForDelRangeInGCJob) ) ctx := context.Background() settings := cluster.MakeTestingClusterSettingsWithVersions(v1, v0, false /* initializeVersion */) require.NoError(t, clusterversion.Initialize(ctx, v0, &settings.SV)) - storage.MVCCRangeTombstonesEnabledInMixedClusters.Override(ctx, &settings.SV, true) + storage.MVCCRangeTombstonesEnabledInMixedClusters.Override(ctx, &settings.SV, false) testServer, sqlDB, kvDB := serverutils.StartServer(t, base.TestServerArgs{ Settings: settings, Knobs: base.TestingKnobs{ @@ -95,7 +95,7 @@ SELECT count(*) WHERE job_type = 'SCHEMA CHANGE GC' AND status = 'paused'`, [][]string{{"2"}}) - tdb.ExpectErr(t, `verifying precondition for version \d*22.1-\d+: `+ + tdb.ExpectErr(t, `verifying precondition for version \d*22.2-\d+: `+ `paused GC jobs prevent upgrading GC job behavior: \[\d+ \d+]`, "SET CLUSTER SETTING version = crdb_internal.node_executable_version()")