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

keys: support splitting Ranges on tenant-id prefixed keys #48138

Merged
merged 3 commits into from
Apr 29, 2020

Conversation

nvanbenschoten
Copy link
Member

Fixes #48122.
Relates to #47903.
Relates to #48123.

This PR contains a series of small commits that work towards the introduction of tenant-id prefixed keyspaces and begin the removal of some keys.TODOSQLCodec instances. This should be the only time we need to touch C++ throughout this work.

@nvanbenschoten nvanbenschoten added the A-multitenancy Related to multi-tenancy label Apr 29, 2020
@cockroach-teamcity
Copy link
Member

This change is Reviewable

@nvanbenschoten nvanbenschoten requested a review from tbg April 29, 2020 02:10
Copy link
Member

@tbg tbg left a comment

Choose a reason for hiding this comment

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

:lgtm:

Reviewed 2 of 2 files at r1, 9 of 9 files at r2, 1 of 1 files at r3.
Reviewable status: :shipit: complete! 1 of 0 LGTMs obtained (waiting on @nvanbenschoten)


c-deps/libroach/encoding.cc, line 289 at r2 (raw file):

  buf->remove_prefix(1);
  uint64_t tid;
  return DecodeUvarint64(buf, &tid);

Oh, so this mutates the Slice*? Interesting, wouldn't have guessed.


c-deps/libroach/encoding_test.cc, line 80 at r2 (raw file):

}

TEST(Libroach, DecodeTenantAndTablePrefix) {

This mirrors go tests, right? Mind throwing in a comment about which one.


pkg/keys/keys.go, line 696 at r1 (raw file):

	// Strip tenant ID prefix from key.
	tenKey, _, err := DecodeTenantPrefix(key)

nit: you could avoid having two keys float around by changing the code as below:

if key2, _, err := DecodeTenantPrefix(key)
  if err != nil {
    return 0, errors.Errorf("%s: not a valid table key", key)
  }
  if encoding.PeekType(key2) != encoding.Int {
	// Not a table key, so the row prefix is the entire key.
	return n, nil
  }
}
// Rest of the code only looks at the end of `key`, so we don't have to use key2`
// and also we don't have two lengths floating around.

This makes it impossible to use the wrong key below. (Besides, tenKey suggests to me that it's a key with tenant prefix, but here's it's the opposite, so the name is a little odd))

…litKey

This addresses a few TODOs. The changes are tested in `TestEnsureSafeSplitKey`.
These changes are all modeled off of the corresponding Go impls.
@nvanbenschoten nvanbenschoten force-pushed the nvanbenschoten/tenantKey2 branch from 64f56b7 to 493fc81 Compare April 29, 2020 16:50
Copy link
Member Author

@nvanbenschoten nvanbenschoten left a comment

Choose a reason for hiding this comment

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

TFTR!

Reviewable status: :shipit: complete! 0 of 0 LGTMs obtained (and 1 stale) (waiting on @nvanbenschoten and @tbg)


c-deps/libroach/encoding_test.cc, line 80 at r2 (raw file):

Previously, tbg (Tobias Grieger) wrote…

This mirrors go tests, right? Mind throwing in a comment about which one.

No, it's not directly mirroring anything. I just realized we had no direct test coverage for these functions.


pkg/keys/keys.go, line 696 at r1 (raw file):

Previously, tbg (Tobias Grieger) wrote…

nit: you could avoid having two keys float around by changing the code as below:

if key2, _, err := DecodeTenantPrefix(key)
  if err != nil {
    return 0, errors.Errorf("%s: not a valid table key", key)
  }
  if encoding.PeekType(key2) != encoding.Int {
	// Not a table key, so the row prefix is the entire key.
	return n, nil
  }
}
// Rest of the code only looks at the end of `key`, so we don't have to use key2`
// and also we don't have two lengths floating around.

This makes it impossible to use the wrong key below. (Besides, tenKey suggests to me that it's a key with tenant prefix, but here's it's the opposite, so the name is a little odd))

Unfortunately, we need the length of this stripped key down below when performing the colIDLen > uint64(tenN-1) check. I rewrote this a bit though based on your suggestion:

  1. renamed tenKey/tenN to sqlKey/sqlN.
  2. renamed colIDLen/colIDLenByte to colFamIDLen/colFamIDLenByte
  3. updated the comments to discuss how this works with column family 0
  4. added tests using real SQL keys

@nvanbenschoten
Copy link
Member Author

bors r+

@craig
Copy link
Contributor

craig bot commented Apr 29, 2020

Build failed (retrying...)

@craig
Copy link
Contributor

craig bot commented Apr 29, 2020

Build succeeded

@craig craig bot merged commit 456d01b into cockroachdb:master Apr 29, 2020
@nvanbenschoten nvanbenschoten deleted the nvanbenschoten/tenantKey2 branch May 6, 2020 18:11
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
A-multitenancy Related to multi-tenancy
Projects
None yet
Development

Successfully merging this pull request may close these issues.

kv: support tenant ID prefix in libroach::RowCounter
3 participants