Commit 29d82b8
committed
storage: make decode_and_mfp yield more often
We've seen evidence in production of this operator often going more than
5s without yielding, especially during rehydration and large unindexed
SELECTs. This affects interactivity as well as the time between when a
timely-driven Future is woken and when it is scheduled again.
Attempt to fix this with two tweaks to our yield heuristics. First,
decrease the fuel between yields from 1_000_000 to 100_000. Second, also
count each mfp evaluation against our fuel, in case it contains a
restrictive filter.
The new 100_000 constant comes from eyeballing a replica in prod that
was non-interactive. At the time, it was decoding ~300k rows per second,
so 100k doesn't seem terribly low in comparison.1 parent 83e2171 commit 29d82b8
5 files changed
Lines changed: 19 additions & 8 deletions
File tree
- src
- compute/src
- render
- sink
- storage-operators/src
- storage/src/render
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
234 | 234 | | |
235 | 235 | | |
236 | 236 | | |
237 | | - | |
238 | | - | |
| 237 | + | |
| 238 | + | |
| 239 | + | |
239 | 240 | | |
240 | 241 | | |
241 | 242 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
102 | 102 | | |
103 | 103 | | |
104 | 104 | | |
105 | | - | |
106 | | - | |
| 105 | + | |
| 106 | + | |
| 107 | + | |
107 | 108 | | |
108 | 109 | | |
109 | 110 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
365 | 365 | | |
366 | 366 | | |
367 | 367 | | |
| 368 | + | |
| 369 | + | |
| 370 | + | |
| 371 | + | |
| 372 | + | |
| 373 | + | |
| 374 | + | |
368 | 375 | | |
369 | 376 | | |
370 | 377 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
56 | 56 | | |
57 | 57 | | |
58 | 58 | | |
59 | | - | |
60 | | - | |
| 59 | + | |
| 60 | + | |
| 61 | + | |
61 | 62 | | |
62 | 63 | | |
63 | 64 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
359 | 359 | | |
360 | 360 | | |
361 | 361 | | |
362 | | - | |
363 | | - | |
| 362 | + | |
| 363 | + | |
| 364 | + | |
364 | 365 | | |
365 | 366 | | |
366 | 367 | | |
| |||
0 commit comments