Commit 9ae6ece
rabbit_db: Eliminate the
... by using `keep_while` conditions on bindings and auto-delete
exchanges.
[Why]
The `delete_queue` transaction's anonymous function has to be extracted
by Horus, like any Khepri transaction. This is an expensive operation,
but Horus uses caching to avoid most work after the first extraction.
Unfortunately, even with this caching, this transaction is still very
expensive when there are massive simultaneous deletions of queues. For
instance when the queues' lifetime is linked to that of many clients,
and all these clients get disconnected at once.
[How]
This patch removes the transaction entirely. Instead, it uses
`keep_while` conditions on bindings and auto-delete exchanges to let
Khepri handle the deletion of semantically related tree nodes. RabbitMQ
just has to make a simle "delete this queue" command.
To maintain backward compatibility, we introduce the
`tie_binding_to_dest_with_keep_while_cond` feature flag. Its `enable`
callback will take care of rewriting all bindings and auto-delete
exchanges record in the store to add the new `keep_while` conditions.
The binding deletion transaction is also simplified because it benefits
from the `keep_while` conditions. We may be able to replace this
transaction is the future as well in the same manner.
(cherry picked from commit de43879)delete_queue Khepri transaction1 parent c2c91e4 commit 9ae6ece
5 files changed
Lines changed: 518 additions & 51 deletions
File tree
- deps/rabbit
- src
- test
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
232 | 232 | | |
233 | 233 | | |
234 | 234 | | |
| 235 | + | |
| 236 | + | |
| 237 | + | |
| 238 | + | |
| 239 | + | |
| 240 | + | |
| 241 | + | |
| 242 | + | |
| 243 | + | |
| 244 | + | |
| 245 | + | |
| 246 | + | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
31 | 31 | | |
32 | 32 | | |
33 | 33 | | |
34 | | - | |
| 34 | + | |
| 35 | + | |
| 36 | + | |
35 | 37 | | |
36 | 38 | | |
37 | 39 | | |
| |||
123 | 125 | | |
124 | 126 | | |
125 | 127 | | |
| 128 | + | |
| 129 | + | |
| 130 | + | |
| 131 | + | |
| 132 | + | |
| 133 | + | |
126 | 134 | | |
127 | 135 | | |
128 | 136 | | |
| |||
132 | 140 | | |
133 | 141 | | |
134 | 142 | | |
135 | | - | |
| 143 | + | |
| 144 | + | |
| 145 | + | |
| 146 | + | |
136 | 147 | | |
137 | 148 | | |
138 | 149 | | |
139 | | - | |
| 150 | + | |
| 151 | + | |
| 152 | + | |
| 153 | + | |
140 | 154 | | |
141 | 155 | | |
142 | 156 | | |
| |||
166 | 180 | | |
167 | 181 | | |
168 | 182 | | |
| 183 | + | |
| 184 | + | |
| 185 | + | |
| 186 | + | |
| 187 | + | |
| 188 | + | |
| 189 | + | |
| 190 | + | |
| 191 | + | |
| 192 | + | |
| 193 | + | |
| 194 | + | |
| 195 | + | |
| 196 | + | |
| 197 | + | |
| 198 | + | |
| 199 | + | |
| 200 | + | |
| 201 | + | |
| 202 | + | |
| 203 | + | |
| 204 | + | |
| 205 | + | |
| 206 | + | |
169 | 207 | | |
170 | 208 | | |
171 | 209 | | |
| |||
190 | 228 | | |
191 | 229 | | |
192 | 230 | | |
193 | | - | |
194 | | - | |
| 231 | + | |
| 232 | + | |
| 233 | + | |
| 234 | + | |
| 235 | + | |
| 236 | + | |
| 237 | + | |
| 238 | + | |
| 239 | + | |
| 240 | + | |
| 241 | + | |
| 242 | + | |
195 | 243 | | |
196 | 244 | | |
197 | 245 | | |
| |||
204 | 252 | | |
205 | 253 | | |
206 | 254 | | |
207 | | - | |
| 255 | + | |
208 | 256 | | |
209 | 257 | | |
210 | 258 | | |
| |||
224 | 272 | | |
225 | 273 | | |
226 | 274 | | |
| 275 | + | |
| 276 | + | |
| 277 | + | |
| 278 | + | |
| 279 | + | |
| 280 | + | |
| 281 | + | |
| 282 | + | |
| 283 | + | |
| 284 | + | |
| 285 | + | |
| 286 | + | |
| 287 | + | |
| 288 | + | |
| 289 | + | |
| 290 | + | |
| 291 | + | |
| 292 | + | |
| 293 | + | |
| 294 | + | |
| 295 | + | |
| 296 | + | |
| 297 | + | |
| 298 | + | |
| 299 | + | |
| 300 | + | |
| 301 | + | |
| 302 | + | |
| 303 | + | |
| 304 | + | |
| 305 | + | |
| 306 | + | |
| 307 | + | |
| 308 | + | |
227 | 309 | | |
228 | 310 | | |
229 | 311 | | |
| |||
232 | 314 | | |
233 | 315 | | |
234 | 316 | | |
235 | | - | |
| 317 | + | |
236 | 318 | | |
237 | 319 | | |
238 | 320 | | |
| |||
247 | 329 | | |
248 | 330 | | |
249 | 331 | | |
| 332 | + | |
| 333 | + | |
| 334 | + | |
| 335 | + | |
| 336 | + | |
| 337 | + | |
| 338 | + | |
| 339 | + | |
| 340 | + | |
| 341 | + | |
| 342 | + | |
| 343 | + | |
| 344 | + | |
| 345 | + | |
| 346 | + | |
250 | 347 | | |
251 | 348 | | |
252 | 349 | | |
| |||
562 | 659 | | |
563 | 660 | | |
564 | 661 | | |
| 662 | + | |
| 663 | + | |
| 664 | + | |
| 665 | + | |
| 666 | + | |
| 667 | + | |
| 668 | + | |
| 669 | + | |
| 670 | + | |
| 671 | + | |
| 672 | + | |
| 673 | + | |
| 674 | + | |
| 675 | + | |
| 676 | + | |
| 677 | + | |
| 678 | + | |
| 679 | + | |
| 680 | + | |
| 681 | + | |
| 682 | + | |
| 683 | + | |
| 684 | + | |
| 685 | + | |
| 686 | + | |
| 687 | + | |
| 688 | + | |
| 689 | + | |
| 690 | + | |
| 691 | + | |
| 692 | + | |
| 693 | + | |
565 | 694 | | |
566 | 695 | | |
567 | 696 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
41 | 41 | | |
42 | 42 | | |
43 | 43 | | |
44 | | - | |
| 44 | + | |
| 45 | + | |
45 | 46 | | |
46 | 47 | | |
47 | 48 | | |
| |||
284 | 285 | | |
285 | 286 | | |
286 | 287 | | |
287 | | - | |
| 288 | + | |
| 289 | + | |
| 290 | + | |
| 291 | + | |
| 292 | + | |
| 293 | + | |
| 294 | + | |
288 | 295 | | |
289 | 296 | | |
290 | 297 | | |
| |||
293 | 300 | | |
294 | 301 | | |
295 | 302 | | |
| 303 | + | |
| 304 | + | |
| 305 | + | |
| 306 | + | |
| 307 | + | |
| 308 | + | |
| 309 | + | |
| 310 | + | |
| 311 | + | |
| 312 | + | |
| 313 | + | |
| 314 | + | |
| 315 | + | |
| 316 | + | |
| 317 | + | |
| 318 | + | |
| 319 | + | |
296 | 320 | | |
297 | 321 | | |
298 | 322 | | |
| |||
0 commit comments