Commit 6276352
authored
We can now store significantly more pre-signatures in advance. The rate
at which these pre-signatures may be consumed is currently determined by
the registry's `max_queue_size` config parameter:
If there are _many_ pre-signatures available, increasing this parameter
allows the replica to accept more signature requests that will be paired
with these pre-signatures. This means pre-signatures will be consumed at
a higher rate, leading to better throughput.
However, if there are _no_ pre-signatures available (i.e. because the
stash was depleted), then increasing the queue size implies a higher
worst case latency for requests sitting at the end of the queue. These
requests have to wait until enough pre-signatures were generated for all
the requests sitting in front.
Therefore, the `max_queue_size` parameter currently represents a
trade-off between maximum throughput and worst case latency.
The solution in this PR is to make the queue size dynamic: As long as
there are still enough pre-signatures available, we accept more
signature requests. If there are no pre-signatures available, then we
only accept at most `max_queue_size` requests, as before.
Since we don't want to accept too many requests, even if there are more
pre-signatures available, the dynamic queue size is additionally capped
by a new constant, that is currently set to 100 requests.
For reference, on mainnet, we currently store 100 pre-signatures per
key. The `max_queue_size` is set to 20 for ECDSA and 30 for Schnorr.
1 parent 89cc1c2 commit 6276352
File tree
3 files changed
+132
-6
lines changed- rs
- execution_environment/src
- execution_environment
- limits/src
3 files changed
+132
-6
lines changed| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
33 | 33 | | |
34 | 34 | | |
35 | 35 | | |
36 | | - | |
| 36 | + | |
| 37 | + | |
| 38 | + | |
37 | 39 | | |
38 | 40 | | |
39 | 41 | | |
| |||
61 | 63 | | |
62 | 64 | | |
63 | 65 | | |
64 | | - | |
65 | | - | |
66 | | - | |
| 66 | + | |
| 67 | + | |
| 68 | + | |
67 | 69 | | |
68 | 70 | | |
69 | 71 | | |
70 | 72 | | |
71 | 73 | | |
72 | 74 | | |
73 | 75 | | |
| 76 | + | |
74 | 77 | | |
75 | 78 | | |
76 | 79 | | |
| |||
3547 | 3550 | | |
3548 | 3551 | | |
3549 | 3552 | | |
3550 | | - | |
| 3553 | + | |
3551 | 3554 | | |
3552 | 3555 | | |
3553 | 3556 | | |
| |||
3624 | 3627 | | |
3625 | 3628 | | |
3626 | 3629 | | |
| 3630 | + | |
| 3631 | + | |
| 3632 | + | |
| 3633 | + | |
| 3634 | + | |
| 3635 | + | |
3627 | 3636 | | |
3628 | 3637 | | |
3629 | 3638 | | |
3630 | 3639 | | |
3631 | 3640 | | |
3632 | | - | |
| 3641 | + | |
3633 | 3642 | | |
3634 | 3643 | | |
3635 | 3644 | | |
| |||
4792 | 4801 | | |
4793 | 4802 | | |
4794 | 4803 | | |
| 4804 | + | |
| 4805 | + | |
| 4806 | + | |
| 4807 | + | |
| 4808 | + | |
| 4809 | + | |
| 4810 | + | |
| 4811 | + | |
| 4812 | + | |
| 4813 | + | |
| 4814 | + | |
| 4815 | + | |
| 4816 | + | |
| 4817 | + | |
| 4818 | + | |
| 4819 | + | |
| 4820 | + | |
| 4821 | + | |
| 4822 | + | |
| 4823 | + | |
| 4824 | + | |
| 4825 | + | |
| 4826 | + | |
| 4827 | + | |
| 4828 | + | |
| 4829 | + | |
Lines changed: 87 additions & 0 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
3 | 3 | | |
4 | 4 | | |
5 | 5 | | |
| 6 | + | |
6 | 7 | | |
7 | 8 | | |
8 | 9 | | |
| |||
19 | 20 | | |
20 | 21 | | |
21 | 22 | | |
| 23 | + | |
22 | 24 | | |
23 | 25 | | |
24 | 26 | | |
25 | 27 | | |
| 28 | + | |
26 | 29 | | |
27 | 30 | | |
28 | 31 | | |
| |||
32 | 35 | | |
33 | 36 | | |
34 | 37 | | |
| 38 | + | |
35 | 39 | | |
36 | 40 | | |
37 | 41 | | |
| |||
44 | 48 | | |
45 | 49 | | |
46 | 50 | | |
| 51 | + | |
47 | 52 | | |
48 | 53 | | |
49 | 54 | | |
| |||
4605 | 4610 | | |
4606 | 4611 | | |
4607 | 4612 | | |
| 4613 | + | |
| 4614 | + | |
| 4615 | + | |
| 4616 | + | |
| 4617 | + | |
| 4618 | + | |
| 4619 | + | |
| 4620 | + | |
| 4621 | + | |
| 4622 | + | |
| 4623 | + | |
| 4624 | + | |
| 4625 | + | |
| 4626 | + | |
| 4627 | + | |
| 4628 | + | |
| 4629 | + | |
| 4630 | + | |
| 4631 | + | |
| 4632 | + | |
| 4633 | + | |
| 4634 | + | |
| 4635 | + | |
| 4636 | + | |
| 4637 | + | |
| 4638 | + | |
| 4639 | + | |
| 4640 | + | |
| 4641 | + | |
| 4642 | + | |
| 4643 | + | |
| 4644 | + | |
| 4645 | + | |
| 4646 | + | |
| 4647 | + | |
| 4648 | + | |
| 4649 | + | |
| 4650 | + | |
| 4651 | + | |
| 4652 | + | |
| 4653 | + | |
| 4654 | + | |
| 4655 | + | |
| 4656 | + | |
| 4657 | + | |
| 4658 | + | |
| 4659 | + | |
| 4660 | + | |
| 4661 | + | |
| 4662 | + | |
| 4663 | + | |
| 4664 | + | |
| 4665 | + | |
| 4666 | + | |
| 4667 | + | |
| 4668 | + | |
| 4669 | + | |
| 4670 | + | |
| 4671 | + | |
| 4672 | + | |
| 4673 | + | |
| 4674 | + | |
| 4675 | + | |
| 4676 | + | |
| 4677 | + | |
| 4678 | + | |
| 4679 | + | |
| 4680 | + | |
| 4681 | + | |
| 4682 | + | |
| 4683 | + | |
| 4684 | + | |
| 4685 | + | |
| 4686 | + | |
| 4687 | + | |
| 4688 | + | |
| 4689 | + | |
| 4690 | + | |
| 4691 | + | |
| 4692 | + | |
| 4693 | + | |
| 4694 | + | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
96 | 96 | | |
97 | 97 | | |
98 | 98 | | |
| 99 | + | |
| 100 | + | |
| 101 | + | |
| 102 | + | |
0 commit comments