-
Notifications
You must be signed in to change notification settings - Fork 2.1k
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
Feature Request: support ranges of shards in VTOrc --clusters_to_watch
#17537
Comments
To play devil's advocate with myself here, range support in the existing Also what if there WAS a A new flag for specifying ranges, or a boolean-flag to enable range support might make this more predictable for users |
How about making this flag dynamic and providing it in a config file? It would then not require a restart.
|
Messaging has a |
Here are my thoughts - I don't think we'd have any trouble with ambiguity because we can make the custom to still accept a list of shard ranges, but we would internally change to watch shards that are a subset of what's specified too. What I mean is in the example I took above, if the user just says The only perceivable problem that I think can happen is if the users misconfigure their VTOrcs to have a shard range that doesn't exactly match the shard splits. For example, if there are only 8 shards, and the users give something like And I agree with @deepthi, if we make the flag dynamic, it won't be all that easy to figure out what all we need to invalidate and keep, and I think requiring a restart when this value changes is fine because reshards, etc aren't operations that happen too often. If we make the shard range change being discussed, then this won't be much of an issue anyway. Also, @timvaillancourt as Deepthi pointed out, I am working on a change that shards a Watch on the topo server instead of polling. I have picked up the EDIT: - I have created a draft PR with the changes I have now so that you can see what I am trying to do and where I'm at - #17553 |
@deepthi / @derekperkins / @GuptaManan100 thanks for the great feedback! It's exciting to hear about this other work going on re: a watch model 🎉
For our use case the need to restart isn't much of a problem if we had support for ranges, which avoid the need for a restart every time a shard is added/merged/split. The cases of where a restart is required is reduced, at least, but not eliminated So maybe the config-value being dynamic is a bit out of scope of this issue, but no concerns tackling both at the same time
Good point, I think starting small with just range support in the existing, static
Yes, we consider this an assumed risk of using
@GuptaManan100 sounds good! We're running a POC of this idea already successfully, so I'll work on making that more upstreame-able and the PR can come after yours 👍.
👀 🙇 EDIT: @GuptaManan100 here is the POC logic I'm working on for range support in |
Hello @timvaillancourt! That sounds wonderful! Just one issue, the link for the POC logic leads to a 404 error. Maybe it's not accessible for anyone without access to slackhq? |
@GuptaManan100 ack, 404 resolved I believe: https://github.com/slackhq/vitess/blob/448291cd8a95f95542fadd29aa03dfb019ad2f71/go/vt/vtorc/logic/tablet_discovery.go#L85-L161 |
Actually working on the topo-watch PR I realised it would actually be better to implement this first and use the changes in that PR. So, I made the required changes today - #17604! Please review when you have time ❤ |
@GuptaManan100 great PR, thanks a lot! |
My pleasure! 😍 |
Feature Description
As VTOrc user with many large keyspaces and often-splitting shards, I would like the ability to watch a range of keyspace-shards without having to individually define them in
--clusters_to_watch
and restart all VTOrcs whenever they changeOr as a TL;DR, I would like to tell one VTOrc instance to "watch the first-half of the
foo
keyspace" (or-80
in Vitess terms) and another to "watch the second-half of thefoo
keyspace" (or80-
in Vitess terms).As some background, VTOrc's
--clusters_to_watch
flag allows VTOrc to watch a subset of keyspaces or shards. Changes to this flag require a restart of VTOrc to be applied. If VTOrc is watching a single keyspace (lets say--clusters_to_watch foo
) with more tablets than can be reliably watched, the seemingly only option to scale is to partition/distribute the shards watched across many VTOrc instances. This approach creates a problem, however: now every shard needs to be statically defined in--clusters_to_watch
. What if you add/split or merge a shard? More updates/deploys 👎. What if you forgot to add one too?This feature request proposes
--clusters_to_watch
(or a new flag) allows the user to watch a range of keyspace/shards, for example specifyingfoo/-80
would allow VTOrc to watch "half of thefoo
keyspace" (ie: all shards from-
to80
)cc @GuptaManan100 for 💡s 🙇
Use Case(s)
A VTOrc user with many large keyspaces and often-splitting shards that would like to avoid statically defining (and redeploying)
--clusters_to_watch
for every shardThe text was updated successfully, but these errors were encountered: