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

add option for warming reads to mirror primary read queries onto replicas from vtgates to warm bufferpools #13206

Merged
merged 17 commits into from
Oct 4, 2023

Conversation

olyazavr
Copy link
Contributor

@olyazavr olyazavr commented May 31, 2023

Description

When reparenting to a replica, if that replica has recently been restarted, it will have a cold bufferpool, and for bufferpool-reliant workloads, this means a performance hit for a few minutes until the bufferpool of the new primary warms up.

As such, it would be great to have the ability to mirror a certain percentage of SELECTs from the current primary to the replicas at the vtgate level, so that when time comes to reparent, the replicas will have a warmer bufferpool than before and not suffer this consequence.

This adds three vtgate flags that can be used to enable and control mirroring a percentage of SELECTs from the current primary to replicas.

      --warming-reads-percent int                                        Percentage of reads on the primary to forward to replicas. Useful for keeping buffer pools warm (default 0)
      --warming-reads-concurrency int                                    Number of concurrent warming reads allowed     (default 500)
      --warming-reads-query-timeout duration                             Timeout of warming read queries (default 5s)

We've been running with this feature at HubSpot for years now and it has significantly improved performance during reparents/rolling restarts. Previously, rolling servers to release a fix/feature was risky and could impact running apps and customers, but now it's something invisible, largely because we are no longer reparenting to a replica with a cold bufferpool

Related Issue(s)

Fixes #13205

Checklist

  • "Backport to:" labels have been added if this change should be back-ported
  • Tests were added or are not required
  • Did the new or modified tests pass consistently locally and on the CI
  • Documentation was added or is not required

Deployment Notes

@vitess-bot vitess-bot bot added NeedsDescriptionUpdate The description is not clear or comprehensive enough, and needs work NeedsIssue A linked issue is missing for this Pull Request NeedsWebsiteDocsUpdate What it says labels May 31, 2023
@vitess-bot
Copy link
Contributor

vitess-bot bot commented May 31, 2023

Review Checklist

Hello reviewers! 👋 Please follow this checklist when reviewing this Pull Request.

General

  • Ensure that the Pull Request has a descriptive title.
  • If this is a change that users need to know about, please apply the release notes (needs details) label so that merging is blocked unless the summary release notes document is included.
  • If a test is added or modified, there should be a documentation on top of the test to explain what the expected behavior is what the test does.

If a new flag is being introduced:

  • Is it really necessary to add this flag?
  • Flag names should be clear and intuitive (as far as possible)
  • Help text should be descriptive.
  • Flag names should use dashes (-) as word separators rather than underscores (_).

If a workflow is added or modified:

  • Each item in Jobs should be named in order to mark it as required.
  • If the workflow should be required, the maintainer team should be notified.

Bug fixes

  • There should be at least one unit or end-to-end test.
  • The Pull Request description should include a link to an issue that describes the bug.

Non-trivial changes

  • There should be some code comments as to why things are implemented the way they are.

New/Existing features

  • Should be documented, either by modifying the existing documentation or creating new documentation.
  • New features should have a link to a feature request issue or an RFC that documents the use cases, corner cases and test cases.

Backward compatibility

  • Protobuf changes should be wire-compatible.
  • Changes to _vt tables and RPCs need to be backward compatible.
  • vtctl command output order should be stable and awk-able.
  • RPC changes should be compatible with vitess-operator
  • If a flag is removed, then it should also be removed from VTop, if used there.

@github-actions github-actions bot added this to the v17.0.0 milestone May 31, 2023
@timvaillancourt
Copy link
Contributor

timvaillancourt commented Jun 2, 2023

@olyazavr this is really cool! 🎉

I wonder if this could more "observable". Is it possible to add *stats.Counter of total reads mirrored and any thoughts on other useful metrics?

Assuming REPLICA is the only tablet type warmed I think keyspace+shard would be useful labels for additional metrics

@jfg956
Copy link
Contributor

jfg956 commented Jun 2, 2023

@timvaillancourt : metrics in the vtgate about warm-up might generate a large metric volume, which makes me think it is not the best place to have this observability. What would you think of putting these metrics on the vttablet ?

@timvaillancourt
Copy link
Contributor

timvaillancourt commented Jun 4, 2023

@timvaillancourt : metrics in the vtgate about warm-up might generate a large metric volume, which makes me think it is not the best place to have this observability. What would you think of putting these metrics on the vttablet ?

@jfg956 that's a good idea that has given me a few more ideas 👍

I think a single vtgate stat of total warmup queries would still be useful. If vttablet has better metrics there would be no need for metric labels, it would just help explain how much traffic comes from where at a high level, vttablet would explain the rest

I think vttablet being aware of "warmup" means querypb.ExecuteOptions will need a new field to tell vttablet this is happening. vttablet having that state would be awesome because:

  1. The query throttling Slack is building could consider this "warmup" field and throttle (during overload)
  2. vttablet could return an empty result to vtgate (because it's not read) if it knows a query is for warmup
  3. Maybe updates to query plan stats could be skipped for warming queries, because the cost of warmed queries is expected to be bad - this probably pollutes stats for a while

Last, a deferrable new question: Is there an upper limit to how many queries vtgate will warm at once? I see there is a "percentage" control but what if those queries take a very long time, let's say each takes the full default 30 second query timeout - could vtgate spawn too may goroutines or something along those lines? Maybe implementing a "warmup pool" vs just using go func would be an optimization for the future? 🤔

@frouioui frouioui modified the milestones: v17.0.0, v18.0.0 Jun 12, 2023
@olyazavr
Copy link
Contributor Author

@timvaillancourt those are all really good ideas! I'm waiting to get some sort of approval or comment from Vitess team that this is even a feature they would consider merging before I go and implement more parts of this

@timvaillancourt
Copy link
Contributor

@timvaillancourt those are all really good ideas! I'm waiting to get some sort of approval or comment from Vitess team that this is even a feature they would consider merging before I go and implement more parts of this

@olyazavr makes sense! They're all deferrable ideas, don't let them block things 👍. Let me know if I can help with anything

Copy link
Collaborator

@maxenglander maxenglander left a comment

Choose a reason for hiding this comment

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

Hey @olyazavr this is awesome, and something I am excited to see land. I work at PlanetScale, my review does not carry the power of approval. I think you can continue to hold off on making changes until someone from the Vitess eng. team chimes in. That said, left some questions and small suggestions.

At a higher-level, had some bigger questions:

  • From your experience using this in production, what CPU/memory impact have you observed on VTGates? What about overall performance?
  • I think it might be nice to have the option to change this value at runtime. If setting 1-2% for warming has a noticeable impact on overall performance, this might be something we only want to set during a maintenance window prior to PRS. No idea how much work it would be to incorporate structural support for this in your PR. If it's a lot I imagine it could be added later on.

I know that the Vitess eng. team will eventually request an addition to changelog/ and a website PR, so noting that as well. I also think adding or modifying existing E2E tests would be a good idea and something they will likely request.

go/flags/endtoend/vtgate.txt Outdated Show resolved Hide resolved
return
}

go func(replicaVCursor VCursor) {
Copy link
Collaborator

Choose a reason for hiding this comment

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

+1 to the idea in the main thread to have a warming pool or something else that caps the inflight warming requests.

executor.normalize = true
session := NewSafeSession(&vtgatepb.Session{TargetString: KsTestUnsharded})

_, err := executor.Execute(context.Background(), "TestSelect", session, "select age, city from user", map[string]*querypb.BindVariable{})
Copy link
Collaborator

Choose a reason for hiding this comment

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

Looks like missing mysqlCtx argument between the context and the method.

callerId := callerid.EffectiveCallerIDFromContext(ctx)
immediateCallerId := callerid.ImmediateCallerIDFromContext(ctx)

timedCtx, _ := context.WithTimeout(context.Background(), 5*time.Second)
Copy link
Collaborator

Choose a reason for hiding this comment

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

Might be nice to pull this 5*time.Second up into a constant, make it configurable by flag, or maybe default to --query-timeout.

Copy link
Collaborator

Choose a reason for hiding this comment

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

Also, not sure if this is something we could/woud want to use:

func addQueryTimeout(ctx context.Context, vcursor VCursor, queryTimeout int) (context.Context, context.CancelFunc) {

Copy link
Collaborator

Choose a reason for hiding this comment

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

Or this?

func (session *SafeSession) SetQueryTimeout(queryTimeout int64) {

go/vt/vtgate/vcursor_impl.go Show resolved Hide resolved
executor.normalize = true
session := NewSafeSession(&vtgatepb.Session{TargetString: KsTestUnsharded})

_, err := executor.Execute(context.Background(), "TestSelect", session, "select age, city from user", map[string]*querypb.BindVariable{})
Copy link
Collaborator

Choose a reason for hiding this comment

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

Would be nice to modify this test so that it runs through a bunch of different cases which exercise the various case statements you have in executeWarmingReplicaRead, and also some tests for negatives like insert, update, and queries that compose select with insert and update.

Copy link
Collaborator

Choose a reason for hiding this comment

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

Would also be good to add tests with trailing comments to see how that lands on the replicas.

@@ -1498,7 +1498,7 @@ func TestStreamSelectIN(t *testing.T) {
}

func createExecutor(serv *sandboxTopo, cell string, resolver *Resolver) *Executor {
return NewExecutor(context.Background(), serv, cell, resolver, false, false, testBufferSize, cache.DefaultConfig, nil, false, querypb.ExecuteOptions_V3)
return NewExecutor(context.Background(), serv, cell, resolver, false, false, testBufferSize, cache.DefaultConfig, nil, false, querypb.ExecuteOptions_V3, 0)
Copy link
Collaborator

Choose a reason for hiding this comment

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

Query serving team may disagree to me, but might be good to set this to a number greater than 0 to help shake out any issues over the next release cycle.

Copy link
Contributor Author

Choose a reason for hiding this comment

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

This would create nondeterministic replica queries, which can make for flakey tests (we encountered this problem)

@@ -3025,7 +3025,7 @@ func TestStreamOrderByLimitWithMultipleResults(t *testing.T) {
count++
}

executor := NewExecutor(context.Background(), serv, cell, resolver, true, false, testBufferSize, cache.DefaultConfig, nil, false, querypb.ExecuteOptions_V3)
executor := NewExecutor(context.Background(), serv, cell, resolver, true, false, testBufferSize, cache.DefaultConfig, nil, false, querypb.ExecuteOptions_V3, 0)
Copy link
Collaborator

Choose a reason for hiding this comment

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

Same thought here and everywhere else.

GetWarmingReadsPercent() int

// CloneForReplicaWarming clones the VCursor for re-use in warming queries to replicas
CloneForReplicaWarming(ctx context.Context) interface{}
Copy link
Collaborator

Choose a reason for hiding this comment

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

Why return interface{} here instead of VCursor?

return
}

_, _ = replicaVCursor.ExecuteMultiShard(ctx, route, rss, queries, false /* rollbackOnError */, false /* autocommit */)
Copy link
Collaborator

Choose a reason for hiding this comment

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

Might be good to add some stats to add visibility into this.

Copy link
Collaborator

Choose a reason for hiding this comment

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

Ah I see in the main conversation now that there's talk about getting this at the tablet level. FWIW I think it could be useful here in case for whatever reason the queries fail to reach the tablets.

@deepthi
Copy link
Member

deepthi commented Jul 15, 2023

I think it might be nice to have the option to change this value at runtime.

Good point. I think the viper work is actually ready, if you want to use that to make this dynamically configurable.
See #11456 and corresponding docs.

Copy link
Member

@GuptaManan100 GuptaManan100 left a comment

Choose a reason for hiding this comment

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

I really like the idea of warming reads!


func (route *Route) executeWarmingReplicaRead(ctx context.Context, vcursor VCursor, bindVars map[string]*querypb.BindVariable, queries []*querypb.BoundQuery) {
switch route.Opcode {
case Unsharded, Scatter, Equal, EqualUnique, IN:
Copy link
Member

Choose a reason for hiding this comment

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

MultiEqual might also be something to consider in the opcodes to allow.

go/vt/vtgate/engine/route.go Outdated Show resolved Hide resolved
@github-actions
Copy link
Contributor

This PR is being marked as stale because it has been open for 30 days with no activity. To rectify, you may do any of the following:

  • Push additional commits to the associated branch.
  • Remove the stale label.
  • Add a comment indicating why it is not stale.

If no action is taken within 7 days, this PR will be closed.

@github-actions github-actions bot added the Stale Marks PRs as stale after a period of inactivity, which are then closed after a grace period. label Aug 17, 2023
@github-actions
Copy link
Contributor

This PR was closed because it has been stale for 7 days with no activity.

@github-actions github-actions bot closed this Aug 24, 2023
@deepthi deepthi removed the Stale Marks PRs as stale after a period of inactivity, which are then closed after a grace period. label Sep 18, 2023
Olga Shestopalova added 4 commits September 28, 2023 16:34
Signed-off-by: Olga Shestopalova <[email protected]>
Signed-off-by: Olga Shestopalova <[email protected]>
Signed-off-by: Olga Shestopalova <[email protected]>
Signed-off-by: Olga Shestopalova <[email protected]>
Copy link
Member

@GuptaManan100 GuptaManan100 left a comment

Choose a reason for hiding this comment

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

I was able to track down one of the unit test failures to this. Because we aren't passing in the context that we cancel later, instead we pass in context.Background this causes the topo watchers to not shutdown properly, which eventually show up as leaked golang threads -

 noleak.go:56: found unexpected goroutines:
        [Goroutine 50 in state chan receive, with vitess.io/vitess/go/vt/topo/memorytopo.(*Conn).Watch.func1 on top of the stack:
        goroutine 50 [chan receive]:
        vitess.io/vitess/go/vt/topo/memorytopo.(*Conn).Watch.func1()
        	/Users/manangupta/vitess/go/vt/topo/memorytopo/watch.go:56 +0x5c
        created by vitess.io/vitess/go/vt/topo/memorytopo.(*Conn).Watch in goroutine 15
        	/Users/manangupta/vitess/go/vt/topo/memorytopo/watch.go:55 +0x250
        
         Goroutine 51 in state chan receive, with vitess.io/vitess/go/vt/topo.(*Server).WatchSrvVSchema.func1 on top of the stack:
        goroutine 51 [chan receive]:
        vitess.io/vitess/go/vt/topo.(*Server).WatchSrvVSchema.func1()
        	/Users/manangupta/vitess/go/vt/topo/srv_vschema.go:74 +0x9c
        created by vitess.io/vitess/go/vt/topo.(*Server).WatchSrvVSchema in goroutine 15
        	/Users/manangupta/vitess/go/vt/topo/srv_vschema.go:70 +0x14c
        
         Goroutine 52 in state select, with vitess.io/vitess/go/vt/vtgate.(*sandboxTopo).WatchSrvVSchema.func1 on top of the stack:
        goroutine 52 [select]:
        vitess.io/vitess/go/vt/vtgate.(*sandboxTopo).WatchSrvVSchema.func1()
        	/Users/manangupta/vitess/go/vt/vtgate/sandbox_test.go:323 +0x94
        created by vitess.io/vitess/go/vt/vtgate.(*sandboxTopo).WatchSrvVSchema in goroutine 15
        	/Users/manangupta/vitess/go/vt/vtgate/sandbox_test.go:321 +0x16c
        
         Goroutine 59 in state chan receive, with vitess.io/vitess/go/vt/topo/memorytopo.(*Conn).Watch.func1 on top of the stack:
        goroutine 59 [chan receive]:
        vitess.io/vitess/go/vt/topo/memorytopo.(*Conn).Watch.func1()
        	/Users/manangupta/vitess/go/vt/topo/memorytopo/watch.go:56 +0x5c
        created by vitess.io/vitess/go/vt/topo/memorytopo.(*Conn).Watch in goroutine 15
        	/Users/manangupta/vitess/go/vt/topo/memorytopo/watch.go:55 +0x250
        
         Goroutine 60 in state chan receive, with vitess.io/vitess/go/vt/topo.(*Server).WatchSrvVSchema.func1 on top of the stack:
        goroutine 60 [chan receive]:
        vitess.io/vitess/go/vt/topo.(*Server).WatchSrvVSchema.func1()
        	/Users/manangupta/vitess/go/vt/topo/srv_vschema.go:74 +0x9c
        created by vitess.io/vitess/go/vt/topo.(*Server).WatchSrvVSchema in goroutine 15
        	/Users/manangupta/vitess/go/vt/topo/srv_vschema.go:70 +0x14c
        
         Goroutine 61 in state select, with vitess.io/vitess/go/vt/vtgate.(*sandboxTopo).WatchSrvVSchema.func1 on top of the stack:
        goroutine 61 [select]:
        vitess.io/vitess/go/vt/vtgate.(*sandboxTopo).WatchSrvVSchema.func1()
        	/Users/manangupta/vitess/go/vt/vtgate/sandbox_test.go:323 +0x94
        created by vitess.io/vitess/go/vt/vtgate.(*sandboxTopo).WatchSrvVSchema in goroutine 15
        	/Users/manangupta/vitess/go/vt/vtgate/sandbox_test.go:321 +0x16c
        ]

go/vt/vtgate/executor_framework_test.go Outdated Show resolved Hide resolved
go/vt/vtgate/executor_select_test.go Outdated Show resolved Hide resolved
@GuptaManan100
Copy link
Member

I would have committed these changes directly, but unfortunately I don't have the access to do that 😢

go/vt/vtgate/executor_select_test.go Outdated Show resolved Hide resolved
go/vt/vtgate/executor_select_test.go Outdated Show resolved Hide resolved
utils.MustMatch(t, wantQueriesReplica, replica.Queries)
replica.Queries = nil

_, err = executor.Execute(ctx, nil, "TestSelect", session, "insert into user (age, city) values (5, 'Boston')", map[string]*querypb.BindVariable{})
Copy link
Member

Choose a reason for hiding this comment

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

Suggested change
_, err = executor.Execute(ctx, nil, "TestSelect", session, "insert into user (age, city) values (5, 'Boston')", map[string]*querypb.BindVariable{})
_, err = executor.Execute(ctx, nil, "TestWarmingReads", session, "insert into user (age, city) values (5, 'Boston')", map[string]*querypb.BindVariable{})

go/vt/vtgate/executor_select_test.go Outdated Show resolved Hide resolved
go/vt/vtgate/executor_select_test.go Outdated Show resolved Hide resolved
go/vt/vtgate/executor_select_test.go Outdated Show resolved Hide resolved
Copy link
Member

@GuptaManan100 GuptaManan100 left a comment

Choose a reason for hiding this comment

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

TestHelpOutput is also failing -

--- FAIL: TestHelpOutput (0.70s)
    --- FAIL: TestHelpOutput/vtcombo (0.06s)
        flags_test.go:142: []: (-want +got)
              (
              	"""
              	... // 421 identical lines
              	      --vttablet_skip_buildinfo_tags string                              comma-separated list of buildinfo tags to skip from merging with --init_tags. each tag is either an exact match or a regular expression of the form '/regexp/'. (default "/.*/")
              	      --wait_for_backup_interval duration                                (init restore parameter) if this is greater than 0, instead of starting up empty when no backups are found, keep checking at this interval for a backup to appear
            + 	      --warming-reads-percent int                                        Percentage of reads on the primary to forward to replicas. Useful for keeping buffer pools warm (default 0)
            + 	      --warming-reads-pool-size int                                      Size of goroutine pool for warming reads (default 500) (default 500)
            + 	      --warming-reads-query-timeout duration                             Timeout of warming read queries (default 5s) (default 5s)
              	      --warn_memory_rows int                                             Warning threshold for in-memory results. A row count higher than this amount will cause the VtGateWarnings.ResultsExceeded counter to be incremented. (default 30000)
              	      --warn_payload_size int                                            The warning threshold for query payloads in bytes. A payload greater than this threshold will cause the VtGateWarnings.WarnPayloadSizeExceeded counter to be incremented.
              	... // 11 identical lines
              	"""
              )
    --- FAIL: TestHelpOutput/vtgate (0.10s)
        flags_test.go:142: []: (-want +got)
              strings.Join({
              	... // 32472 identical bytes
              	"\n      --warming-reads-pool-size int                            ",
              	"          Size of goroutine pool for warming reads (default 500)",
            + 	" (default 500)",
              	"\n      --warming-reads-query-timeout duration                   ",
              	"          Timeout of warming read queri",
            + 	"es (d",
              	"e",
            + 	"fault 5",
              	"s",
            + 	")",
              	" (default 5s)\n      --warn_memory_rows int                      ",
              	"                       Warning threshold for in-memory results. ",
              	... // 563 identical bytes
              }, "")
FAIL

This requires fixing the vtgate.txt and vtcombo.txt file in the flags/endtoend directory to match the new expectation.

olyazavr and others added 2 commits September 29, 2023 09:46
Co-authored-by: Manan Gupta <[email protected]>
Signed-off-by: Olga Shestopalova <[email protected]>
@frouioui frouioui modified the milestones: v18.0.0, v19.0.0 Sep 29, 2023
@@ -421,6 +421,9 @@ Flags:
--vtgate_grpc_server_name string the server name to use to validate server certificate
--vttablet_skip_buildinfo_tags string comma-separated list of buildinfo tags to skip from merging with --init_tags. each tag is either an exact match or a regular expression of the form '/regexp/'. (default "/.*/")
--wait_for_backup_interval duration (init restore parameter) if this is greater than 0, instead of starting up empty when no backups are found, keep checking at this interval for a backup to appear
--warming-reads-percent int Percentage of reads on the primary to forward to replicas. Useful for keeping buffer pools warm (default 0)
--warming-reads-pool-size int Size of goroutine pool for warming reads (default 500)
Copy link
Member

Choose a reason for hiding this comment

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

In Vitess, pools usually mean connection pools. When I read the description I thought it's a waitGroup or something like that. Actually it turns out to be a channel bool whose capacity is set by this flag.
The flag name and description are misleading. They need to be changed to reflect the actual usage. It should be something like --warming-reads-concurrency and be documented as Number of concurrent warming reads allowed.

Copy link
Member

Choose a reason for hiding this comment

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

I edited the PR description at the top to list all 3 flags. Once these changes are made, that needs to change again.

@deepthi deepthi added the NeedsDescriptionUpdate The description is not clear or comprehensive enough, and needs work label Sep 29, 2023
@deepthi
Copy link
Member

deepthi commented Sep 29, 2023

So close. flags_test is still failing. you can fix that after addressing the feedback and then this will be almost ready to go.

@deepthi
Copy link
Member

deepthi commented Sep 29, 2023

@ajm188 given https://vitess.slack.com/archives/CMDJ2KFEZ/p1695982611699689 can we say that this PR does not need a separate website docs PR to update the flags?

@ajm188
Copy link
Contributor

ajm188 commented Sep 29, 2023

Yep that's correct!

@deepthi deepthi removed the NeedsWebsiteDocsUpdate What it says label Sep 29, 2023
Signed-off-by: Olga Shestopalova <[email protected]>
Copy link
Member

@GuptaManan100 GuptaManan100 left a comment

Choose a reason for hiding this comment

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

lgtm

@olyazavr
Copy link
Contributor Author

olyazavr commented Oct 4, 2023

What else is needed for approval here?

@GuptaManan100 GuptaManan100 removed the NeedsDescriptionUpdate The description is not clear or comprehensive enough, and needs work label Oct 4, 2023
Copy link
Member

@deepthi deepthi left a comment

Choose a reason for hiding this comment

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

Nice work! Thank you for the contribution!

@deepthi deepthi merged commit f74838e into vitessio:main Oct 4, 2023
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Component: Query Serving Type: Enhancement Logical improvement (somewhere between a bug and feature)
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Feature Request: option to warm up bufferpool with warming reads from primary to replica
8 participants