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

spanconfig: set stage for migration #74266

Merged
merged 4 commits into from
Jan 14, 2022

Conversation

irfansharif
Copy link
Contributor

@irfansharif irfansharif commented Dec 24, 2021

spanconfig: get rid of ReconciliationDependencies interface

It was hollow, simply embedding the spanconfig.Reconciler interface. In
a future commit we end up relying on each pod's span config reconciler
outside of just the reconciliation job. This makes the interface even
awkwarder than it was.

spanconfig/reconciler: export the checkpoint timestamp

We'll make use of it in a future commit.

*kvserver: plumb in a context into (Store).GetConfReader

We'll use it in a future commit.

clusterversion: improve a version comment

Gets rid of a squiggly line in Goland.


Set of commits to set the stage for #73876.

@irfansharif irfansharif requested a review from a team as a code owner December 24, 2021 00:29
@irfansharif irfansharif requested a review from a team December 24, 2021 00:29
@cockroach-teamcity
Copy link
Member

This change is Reviewable

@irfansharif irfansharif requested review from nvanbenschoten, arulajmani and ajwerner and removed request for a team December 24, 2021 00:30
@irfansharif irfansharif force-pushed the 211223.spanconfigs-migration branch from c363767 to 4ce2bb6 Compare December 24, 2021 00:42
@irfansharif irfansharif changed the title migration: migrate into span configs infrastructure migration: migrate into span configs Dec 24, 2021
@irfansharif
Copy link
Contributor Author

(Gentle bump.)

Copy link
Collaborator

@arulajmani arulajmani left a comment

Choose a reason for hiding this comment

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

Reviewed 1 of 1 files at r1, 7 of 7 files at r2, 7 of 7 files at r3, 9 of 9 files at r4, 9 of 13 files at r5, all commit messages.
Reviewable status: :shipit: complete! 0 of 0 LGTMs obtained (waiting on @ajwerner, @arulajmani, @irfansharif, and @nvanbenschoten)


pkg/migration/migrations/migrate_span_configs.go, line 34 at r5 (raw file):

	for r := retry.StartWithCtx(ctx, base.DefaultRetryOptions()); r.Next(); {
		if !d.SpanConfig.Reconciler.Checkpoint().IsEmpty() {

I'm not very familiar with the migrations framework, but how would things work if this is run on a node that isn't running the reconciliation job?


pkg/migration/migrations/migrations.go, line 156 at r5 (raw file):

		insertMissingPublicSchemaNamespaceEntry,
	),
	migration.NewTenantMigration(

Should this be a NewSystemMigration as well?


pkg/migration/migrations/migrate_span_configs_test.go, line 43 at r5 (raw file):

	tc := testcluster.StartTestCluster(t, 1, base.TestClusterArgs{
		ServerArgs: base.TestServerArgs{
			EnableSpanConfigs: true,

I took this for a spin, is this failing because we haven't turned on the cluster settings to create the reconciliation job?

Gets rid of a squiggly line in Goland.

Release note: None
We'll use it in a future commit.

Release note: None
We'll make use of it in a future commit.

Release note: None
It was hollow, simply embedding the spanconfig.Reconciler interface. In
a future commit we end up relying on each pod's span config reconciler
outside of just the reconciliation job. This makes the interface even
awkwarder than it was.

Release note: None
Copy link
Contributor

@ajwerner ajwerner left a comment

Choose a reason for hiding this comment

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

Reviewed 1 of 1 files at r1, 7 of 7 files at r2, 7 of 7 files at r3, 9 of 9 files at r4, 13 of 13 files at r5, all commit messages.
Reviewable status: :shipit: complete! 0 of 0 LGTMs obtained (waiting on @arulajmani, @irfansharif, and @nvanbenschoten)


pkg/kv/kvserver/queue_helpers_testutil.go, line 55 at r2 (raw file):

// enqueues any that need to be replicated.
func (s *Store) ForceReplicationScanAndProcess() error {
	return forceScanAndProcess(context.TODO(), s, s.replicateQueue.baseQueue)

IIRC elsewhere we've decided that for testing calls like this we just use context.Background.


pkg/migration/migrations/migrate_span_configs.go, line 34 at r5 (raw file):

Previously, arulajmani (Arul Ajmani) wrote…

I'm not very familiar with the migrations framework, but how would things work if this is run on a node that isn't running the reconciliation job?

☝️, I think we need to persist the checkpoint as a pre-req to making this migration work. It's also a task we need to do anyway


pkg/migration/migrations/migrations.go, line 156 at r5 (raw file):

Previously, arulajmani (Arul Ajmani) wrote…

Should this be a NewSystemMigration as well?

NewTenantMigration is run on the system tenant too

@irfansharif irfansharif force-pushed the 211223.spanconfigs-migration branch from 4ce2bb6 to 1b1a3b0 Compare January 13, 2022 17:59
@irfansharif irfansharif requested a review from a team as a code owner January 13, 2022 17:59
@irfansharif irfansharif force-pushed the 211223.spanconfigs-migration branch from 1b1a3b0 to aeb410a Compare January 13, 2022 18:12
Copy link
Contributor Author

@irfansharif irfansharif left a comment

Choose a reason for hiding this comment

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

TFTRs! I thought this PR would be cleanly separable from the one enabling everything by default, but it isn't. The migrations here depend on the reconciliation job running, and that in turn depends on the infra being enabled. Given that, here's what I think we should do:

Does that work?

Reviewable status: :shipit: complete! 0 of 0 LGTMs obtained (waiting on @ajwerner, @arulajmani, and @nvanbenschoten)


pkg/kv/kvserver/queue_helpers_testutil.go, line 55 at r2 (raw file):

Previously, ajwerner wrote…

IIRC elsewhere we've decided that for testing calls like this we just use context.Background.

Everything else in this file is using context.TODO(), just did it for that reason.


pkg/migration/migrations/migrate_span_configs.go, line 34 at r5 (raw file):

Previously, ajwerner wrote…

☝️, I think we need to persist the checkpoint as a pre-req to making this migration work. It's also a task we need to do anyway

Done. We're still not actually using the checkpoint, just persisting it. Using it is just slightly more involved (need a few reconciler changes to detect if system.{zones,descriptor} haven't already been GC-ed at the given timestamp). Given this PR is holding up a few others, could we get to it after?


pkg/migration/migrations/migrate_span_configs_test.go, line 43 at r5 (raw file):

Previously, arulajmani (Arul Ajmani) wrote…

I took this for a spin, is this failing because we haven't turned on the cluster settings to create the reconciliation job?

Woops, that's right, had pulled it out of the other PR that enabled it by default so it's failing here.

@shermanCRL shermanCRL requested review from HonoreDB and removed request for a team January 13, 2022 18:18
Copy link
Contributor

@ajwerner ajwerner left a comment

Choose a reason for hiding this comment

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

I'm cool with that.

Reviewable status: :shipit: complete! 0 of 0 LGTMs obtained (waiting on @ajwerner, @arulajmani, @HonoreDB, and @nvanbenschoten)

@irfansharif
Copy link
Contributor Author

The remaining test failures now are expected, just because the infra is disabled but these last migrations need it. Do take a look at the job checkpointing stuff, I'm not really familiar with those libraries. I'll shift to just #73876 once you do.

Copy link
Collaborator

@arulajmani arulajmani left a comment

Choose a reason for hiding this comment

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

:lgtm: for me. I have a mild aesthetic preference for reverting the commit that exposed the Checkpoint on the Reconciler now that we don't make use of it in the migration.

Reviewed 32 of 32 files at r6, 7 of 7 files at r7, 7 of 7 files at r8, 9 of 9 files at r9, 16 of 16 files at r10, all commit messages.
Reviewable status: :shipit: complete! 1 of 0 LGTMs obtained (waiting on @ajwerner, @arulajmani, @HonoreDB, and @nvanbenschoten)


pkg/migration/migrations/migrations.go, line 156 at r5 (raw file):

Previously, ajwerner wrote…

NewTenantMigration is run on the system tenant too

We don't do any work and return early for secondary tenants though, so maybe we could change this to just run on the system tenant.

@irfansharif
Copy link
Contributor Author

Thanks! Closing this in favor of #73876 now.

@irfansharif irfansharif reopened this Jan 13, 2022
@irfansharif irfansharif force-pushed the 211223.spanconfigs-migration branch from aeb410a to 5d7f4d3 Compare January 13, 2022 22:20
@irfansharif irfansharif changed the title migration: migrate into span configs spanconfig: set stage for migration Jan 13, 2022
@irfansharif
Copy link
Contributor Author

Got rid of the beefy migration commit in this PR, just going the land the rest of the tiny ones.

bors r+

@craig
Copy link
Contributor

craig bot commented Jan 13, 2022

Build failed (retrying...):

@craig
Copy link
Contributor

craig bot commented Jan 14, 2022

Build succeeded:

@craig craig bot merged commit ffe26ec into cockroachdb:master Jan 14, 2022
@irfansharif irfansharif deleted the 211223.spanconfigs-migration branch January 14, 2022 02:53
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants