From c5642a184eafc937d22f73fa3940349e6d2e7d7d Mon Sep 17 00:00:00 2001 From: Nathan VanBenschoten Date: Mon, 11 Feb 2019 13:15:28 -0500 Subject: [PATCH 1/3] kv: remove VersionTxnSpanRefresh gate Release note: None --- pkg/kv/txn_interceptor_span_refresher.go | 2 +- pkg/settings/cluster/cockroach_versions.go | 18 +++++++++--------- 2 files changed, 10 insertions(+), 10 deletions(-) diff --git a/pkg/kv/txn_interceptor_span_refresher.go b/pkg/kv/txn_interceptor_span_refresher.go index a5931b567f60..42c4d7d0dc5c 100644 --- a/pkg/kv/txn_interceptor_span_refresher.go +++ b/pkg/kv/txn_interceptor_span_refresher.go @@ -188,7 +188,7 @@ func (sr *txnSpanRefresher) maybeRetrySend( // Check for an error which can be retried after updating spans. canRetryTxn, retryTxn := roachpb.CanTransactionRetryAtRefreshedTimestamp(ctx, pErr) - if !canRetryTxn || !sr.canAutoRetry || !sr.st.Version.IsActive(cluster.VersionTxnSpanRefresh) { + if !canRetryTxn || !sr.canAutoRetry { return nil, pErr, hlc.Timestamp{} } diff --git a/pkg/settings/cluster/cockroach_versions.go b/pkg/settings/cluster/cockroach_versions.go index cd151f156b2a..4d373d312879 100644 --- a/pkg/settings/cluster/cockroach_versions.go +++ b/pkg/settings/cluster/cockroach_versions.go @@ -30,7 +30,7 @@ type VersionKey int // To delete a version. // - Remove its associated runtime checks. // - If the version is not the latest one, delete the constant and comment out -// its stanza and say "deleted" in the versionsSingleton. +// its stanza and say "Deleted." above the versionsSingleton. const ( VersionBase VersionKey = iota VersionRaftLogTruncationBelowRaft // unused @@ -46,8 +46,8 @@ const ( VersionLeaseSequence // unused VersionUnreplicatedTombstoneKey // unused VersionRecomputeStats - VersionNoRaftProposalKeys // unused - VersionTxnSpanRefresh + VersionNoRaftProposalKeys // unused + VersionTxnSpanRefresh // unused VersionReadUncommittedRangeLookups // unused VersionPerReplicaZoneConstraints VersionLeasePreferences @@ -187,11 +187,11 @@ var versionsSingleton = keyedVersions([]keyedVersion{ Key: VersionNoRaftProposalKeys, Version: roachpb.Version{Major: 1, Minor: 1, Unstable: 11}, }, - { - // VersionTxnSpanRefresh is https://github.com/cockroachdb/cockroach/pull/21140. - Key: VersionTxnSpanRefresh, - Version: roachpb.Version{Major: 1, Minor: 1, Unstable: 12}, - }, + // { + // // VersionTxnSpanRefresh is https://github.com/cockroachdb/cockroach/pull/21140. + // Key: VersionTxnSpanRefresh, + // Version: roachpb.Version{Major: 1, Minor: 1, Unstable: 12}, + // }, { // VersionReadUncommittedRangeLookups is https://github.com/cockroachdb/cockroach/pull/21276. Key: VersionReadUncommittedRangeLookups, @@ -269,7 +269,7 @@ var versionsSingleton = keyedVersions([]keyedVersion{ Key: VersionCreateChangefeed, Version: roachpb.Version{Major: 2, Minor: 0, Unstable: 11}, }, - // deleted + // Removed. // { // // VersionRangeMerges is https://github.com/cockroachdb/cockroach/pull/28865. // Key: VersionRangeMerges, From 0433e5e40ee9e8115f2162ac188c808cd503be61 Mon Sep 17 00:00:00 2001 From: Nathan VanBenschoten Date: Mon, 11 Feb 2019 13:21:18 -0500 Subject: [PATCH 2/3] settings: delete all unused VersionKeys In accordance with 10a7dd3ba79deafd0ed198b27a7cc2679a047898. Release note: None --- pkg/settings/cluster/cockroach_versions.go | 118 ++++++++++----------- 1 file changed, 58 insertions(+), 60 deletions(-) diff --git a/pkg/settings/cluster/cockroach_versions.go b/pkg/settings/cluster/cockroach_versions.go index 4d373d312879..c2a8e0087774 100644 --- a/pkg/settings/cluster/cockroach_versions.go +++ b/pkg/settings/cluster/cockroach_versions.go @@ -29,26 +29,19 @@ type VersionKey int // // To delete a version. // - Remove its associated runtime checks. -// - If the version is not the latest one, delete the constant and comment out -// its stanza and say "Deleted." above the versionsSingleton. +// - If the version is not the latest one, delete the constant, comment out +// its stanza, and say "Removed." above the versionsSingleton. const ( - VersionBase VersionKey = iota - VersionRaftLogTruncationBelowRaft // unused + VersionBase VersionKey = iota VersionSplitHardStateBelowRaft VersionStatsBasedRebalancing Version1_1 VersionMVCCNetworkStats - VersionMeta2Splits // unused VersionRPCNetworkStats VersionRPCVersionCheck VersionClearRange VersionPartitioning - VersionLeaseSequence // unused - VersionUnreplicatedTombstoneKey // unused VersionRecomputeStats - VersionNoRaftProposalKeys // unused - VersionTxnSpanRefresh // unused - VersionReadUncommittedRangeLookups // unused VersionPerReplicaZoneConstraints VersionLeasePreferences Version2_0 @@ -57,10 +50,7 @@ const ( VersionRangeAppliedStateKey VersionImportFormats VersionSecondaryLookupJoins - VersionClientSideWritingFlag // unused VersionColumnarTimeSeries - VersionTxnCoordMetaInvalidField // unused - VersionAsyncConsensus // unused VersionBatchResponse VersionCreateChangefeed VersionBitArrayColumns @@ -101,11 +91,12 @@ var versionsSingleton = keyedVersions([]keyedVersion{ Key: VersionBase, Version: roachpb.Version{Major: 1}, }, - { - // VersionRaftLogTruncationBelowRaft is https://github.com/cockroachdb/cockroach/pull/16993. - Key: VersionRaftLogTruncationBelowRaft, - Version: roachpb.Version{Major: 1, Minor: 0, Unstable: 1}, - }, + // Removed. + // { + // // VersionRaftLogTruncationBelowRaft is https://github.com/cockroachdb/cockroach/pull/16993. + // Key: VersionRaftLogTruncationBelowRaft, + // Version: roachpb.Version{Major: 1, Minor: 0, Unstable: 1}, + // }, { // VersionSplitHardStateBelowRaft is https://github.com/cockroachdb/cockroach/pull/17051. Key: VersionSplitHardStateBelowRaft, @@ -132,11 +123,12 @@ var versionsSingleton = keyedVersions([]keyedVersion{ Key: VersionMVCCNetworkStats, Version: roachpb.Version{Major: 1, Minor: 1, Unstable: 2}, }, - { - // VersionMeta2Splits is https://github.com/cockroachdb/cockroach/pull/18970. - Key: VersionMeta2Splits, - Version: roachpb.Version{Major: 1, Minor: 1, Unstable: 3}, - }, + // Removed. + // { + // // VersionMeta2Splits is https://github.com/cockroachdb/cockroach/pull/18970. + // Key: VersionMeta2Splits, + // Version: roachpb.Version{Major: 1, Minor: 1, Unstable: 3}, + // }, { // VersionRPCNetworkStats is https://github.com/cockroachdb/cockroach/pull/19897. Key: VersionRPCNetworkStats, @@ -167,36 +159,41 @@ var versionsSingleton = keyedVersions([]keyedVersion{ Key: VersionPartitioning, Version: roachpb.Version{Major: 1, Minor: 1, Unstable: 7}, }, - { - // VersionLeaseSequence is https://github.com/cockroachdb/cockroach/pull/20953. - Key: VersionLeaseSequence, - Version: roachpb.Version{Major: 1, Minor: 1, Unstable: 8}, - }, - { - // VersionUnreplicatedTombstoneKey is https://github.com/cockroachdb/cockroach/pull/21120. - Key: VersionUnreplicatedTombstoneKey, - Version: roachpb.Version{Major: 1, Minor: 1, Unstable: 9}, - }, + // Removed. + // { + // // VersionLeaseSequence is https://github.com/cockroachdb/cockroach/pull/20953. + // Key: VersionLeaseSequence, + // Version: roachpb.Version{Major: 1, Minor: 1, Unstable: 8}, + // }, + // Removed. + // { + // // VersionUnreplicatedTombstoneKey is https://github.com/cockroachdb/cockroach/pull/21120. + // Key: VersionUnreplicatedTombstoneKey, + // Version: roachpb.Version{Major: 1, Minor: 1, Unstable: 9}, + // }, { // VersionRecomputeStats is https://github.com/cockroachdb/cockroach/pull/21345. Key: VersionRecomputeStats, Version: roachpb.Version{Major: 1, Minor: 1, Unstable: 10}, }, - { - // VersionNoRaftProposalKeys is https://github.com/cockroachdb/cockroach/pull/20647. - Key: VersionNoRaftProposalKeys, - Version: roachpb.Version{Major: 1, Minor: 1, Unstable: 11}, - }, + // Removed. + // { + // // VersionNoRaftProposalKeys is https://github.com/cockroachdb/cockroach/pull/20647. + // Key: VersionNoRaftProposalKeys, + // Version: roachpb.Version{Major: 1, Minor: 1, Unstable: 11}, + // }, + // Removed. // { // // VersionTxnSpanRefresh is https://github.com/cockroachdb/cockroach/pull/21140. // Key: VersionTxnSpanRefresh, // Version: roachpb.Version{Major: 1, Minor: 1, Unstable: 12}, // }, - { - // VersionReadUncommittedRangeLookups is https://github.com/cockroachdb/cockroach/pull/21276. - Key: VersionReadUncommittedRangeLookups, - Version: roachpb.Version{Major: 1, Minor: 1, Unstable: 13}, - }, + // Removed. + // { + // // VersionReadUncommittedRangeLookups is https://github.com/cockroachdb/cockroach/pull/21276. + // Key: VersionReadUncommittedRangeLookups, + // Version: roachpb.Version{Major: 1, Minor: 1, Unstable: 13}, + // }, { // VersionPerReplicaZoneConstraints is https://github.com/cockroachdb/cockroach/pull/22819. Key: VersionPerReplicaZoneConstraints, @@ -237,28 +234,29 @@ var versionsSingleton = keyedVersions([]keyedVersion{ Key: VersionSecondaryLookupJoins, Version: roachpb.Version{Major: 2, Minor: 0, Unstable: 5}, }, - { - // VersionClientsideWritingFlag is https://github.com/cockroachdb/cockroach/pull/25541. - // Before this version, the Transaction.Writing flag used to be set by the - // server. After, it is set only by the client. - Key: VersionClientSideWritingFlag, - Version: roachpb.Version{Major: 2, Minor: 0, Unstable: 6}, - }, + // Removed. + // { + // // VersionClientsideWritingFlag is https://github.com/cockroachdb/cockroach/pull/25541. + // Key: VersionClientSideWritingFlag, + // Version: roachpb.Version{Major: 2, Minor: 0, Unstable: 6}, + // }, { // VersionColumnarTimeSeries is https://github.com/cockroachdb/cockroach/pull/26614. Key: VersionColumnarTimeSeries, Version: roachpb.Version{Major: 2, Minor: 0, Unstable: 7}, }, - { - // VersionTxnCoordMetaInvalidField is https://github.com/cockroachdb/cockroach/pull/27420. - Key: VersionTxnCoordMetaInvalidField, - Version: roachpb.Version{Major: 2, Minor: 0, Unstable: 8}, - }, - { - // VersionAsyncConsensus is https://github.com/cockroachdb/cockroach/pull/26599. - Key: VersionAsyncConsensus, - Version: roachpb.Version{Major: 2, Minor: 0, Unstable: 9}, - }, + // Removed. + // { + // // VersionTxnCoordMetaInvalidField is https://github.com/cockroachdb/cockroach/pull/27420. + // Key: VersionTxnCoordMetaInvalidField, + // Version: roachpb.Version{Major: 2, Minor: 0, Unstable: 8}, + // }, + // Removed. + // { + // // VersionAsyncConsensus is https://github.com/cockroachdb/cockroach/pull/26599. + // Key: VersionAsyncConsensus, + // Version: roachpb.Version{Major: 2, Minor: 0, Unstable: 9}, + // }, { // VersionBatchResponse is https://github.com/cockroachdb/cockroach/pull/26553. Key: VersionBatchResponse, From 333d48a057f6ac3cdd441f9ce75fa7c576861a07 Mon Sep 17 00:00:00 2001 From: Nathan VanBenschoten Date: Mon, 11 Feb 2019 13:24:32 -0500 Subject: [PATCH 3/3] storage: remove DisallowUnsequencedTransactionalWrites The assertion is no longer necessary and wasn't even being used anymore. Release note: None --- pkg/storage/storagebase/knobs.go | 9 --------- pkg/storage/store.go | 4 ---- 2 files changed, 13 deletions(-) diff --git a/pkg/storage/storagebase/knobs.go b/pkg/storage/storagebase/knobs.go index 7e35aaa2b701..39b6dac4dcab 100644 --- a/pkg/storage/storagebase/knobs.go +++ b/pkg/storage/storagebase/knobs.go @@ -34,15 +34,6 @@ type BatchEvalTestingKnobs struct { // NumKeysEvaluatedForRangeIntentResolution is set by the stores to the // number of keys evaluated for range intent resolution. NumKeysEvaluatedForRangeIntentResolution *int64 - // DisallowUnsequencedTransactionalWrites enables an assertion that all - // transactional writes include Request-scoped sequence numbers. This - // assertion is not safe to enable by default, because it would trigger - // in mixed-version clusters. However, it is useful in testing to ensure - // that tests properly assign these sequence numbers. - // - // TODO(nvanbenschoten): Remove this testing knob in 2.2. The corresponding - // assertion can be performed unconditionally. - DisallowUnsequencedTransactionalWrites bool } // IntentResolverTestingKnobs contains testing helpers that are used during diff --git a/pkg/storage/store.go b/pkg/storage/store.go index ed2925e8e95e..59a0da93f13c 100644 --- a/pkg/storage/store.go +++ b/pkg/storage/store.go @@ -154,10 +154,6 @@ func TestStoreConfig(clock *hlc.Clock) StoreConfig { ClosedTimestamp: container.NoopContainer(), } - // Tests should never send unsequenced transactional writes, - // so we set this testing knob in all tests. - sc.TestingKnobs.EvalKnobs.DisallowUnsequencedTransactionalWrites = true - // Use shorter Raft tick settings in order to minimize start up and failover // time in tests. sc.RaftElectionTimeoutTicks = 3