Commit 08f7033
authored
fix(vespa): handle continuation tokens in selection-based bulk deletes (#1733)
* fix(vespa): propagate delete errors instead of swallowing them
* fix(vespa): use 'contains' instead of '=' for collection_id in fast-delete YQL
The fast-delete path constructs a YQL query to resolve Vespa doc IDs
before issuing parallel direct DELETEs. The query used `= '{uuid}'` for
the collection_id filter, but in Vespa YQL `=` is the numeric equality
operator — it fails on UUID strings with HTTP 400 "not an int item
expression: Illegal embedded sign character" (the `-` in UUIDs).
This caused every fast-delete to fall back to the visitor-based
selection scan (5 schemas × 120s timeout each ≈ 300s per batch),
producing 1,100+ "update_delete_VespaDestination slow: 300.Xs"
warnings per hour in production.
Fix: change `=` to `contains` (the correct YQL string-match operator),
consistent with query_builder.py and vespa_client.py which already
use `contains` for the same field.
* fix(vespa): handle continuation token in selection-based bulk deletes
Vespa visitor-based DELETE returns a continuation token when the
result set is too large for a single pass. The previous implementation
made a single request and ignored the token, silently leaving
undeleted documents behind on large collections.
Now delete_by_selection loops: issue DELETE, check for continuation
token in response, re-issue with continuation param until Vespa
stops returning one. This affects delete_by_sync_id,
delete_by_collection_id, and the entity-level fallback path.
* style: fix ruff format for bulk delete response assignment1 parent 9dad3da commit 08f7033
2 files changed
Lines changed: 178 additions & 13 deletions
File tree
- backend
- airweave/platform/destinations/vespa
- tests/unit/platform/destinations/vespa
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
188 | 188 | | |
189 | 189 | | |
190 | 190 | | |
191 | | - | |
192 | | - | |
| 191 | + | |
| 192 | + | |
| 193 | + | |
193 | 194 | | |
194 | 195 | | |
195 | 196 | | |
| |||
200 | 201 | | |
201 | 202 | | |
202 | 203 | | |
203 | | - | |
| 204 | + | |
204 | 205 | | |
205 | 206 | | |
206 | 207 | | |
| 208 | + | |
| 209 | + | |
| 210 | + | |
207 | 211 | | |
208 | 212 | | |
209 | | - | |
210 | | - | |
211 | | - | |
212 | | - | |
213 | | - | |
| 213 | + | |
| 214 | + | |
| 215 | + | |
| 216 | + | |
| 217 | + | |
| 218 | + | |
| 219 | + | |
| 220 | + | |
| 221 | + | |
| 222 | + | |
| 223 | + | |
| 224 | + | |
| 225 | + | |
| 226 | + | |
| 227 | + | |
| 228 | + | |
| 229 | + | |
| 230 | + | |
| 231 | + | |
| 232 | + | |
| 233 | + | |
| 234 | + | |
| 235 | + | |
214 | 236 | | |
215 | 237 | | |
216 | | - | |
| 238 | + | |
| 239 | + | |
217 | 240 | | |
218 | 241 | | |
219 | 242 | | |
220 | 243 | | |
221 | 244 | | |
222 | | - | |
| 245 | + | |
| 246 | + | |
| 247 | + | |
| 248 | + | |
223 | 249 | | |
224 | 250 | | |
225 | 251 | | |
| |||
477 | 503 | | |
478 | 504 | | |
479 | 505 | | |
480 | | - | |
481 | | - | |
| 506 | + | |
| 507 | + | |
| 508 | + | |
| 509 | + | |
| 510 | + | |
| 511 | + | |
| 512 | + | |
| 513 | + | |
| 514 | + | |
482 | 515 | | |
| 516 | + | |
483 | 517 | | |
484 | 518 | | |
485 | 519 | | |
486 | 520 | | |
487 | 521 | | |
| 522 | + | |
| 523 | + | |
488 | 524 | | |
489 | 525 | | |
490 | 526 | | |
| |||
494 | 530 | | |
495 | 531 | | |
496 | 532 | | |
497 | | - | |
| 533 | + | |
498 | 534 | | |
499 | 535 | | |
500 | 536 | | |
| |||
Lines changed: 129 additions & 0 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
1 | 1 | | |
2 | 2 | | |
| 3 | + | |
| 4 | + | |
| 5 | + | |
| 6 | + | |
3 | 7 | | |
4 | 8 | | |
5 | 9 | | |
| |||
123 | 127 | | |
124 | 128 | | |
125 | 129 | | |
| 130 | + | |
| 131 | + | |
| 132 | + | |
| 133 | + | |
| 134 | + | |
| 135 | + | |
| 136 | + | |
| 137 | + | |
| 138 | + | |
| 139 | + | |
| 140 | + | |
| 141 | + | |
| 142 | + | |
| 143 | + | |
| 144 | + | |
| 145 | + | |
| 146 | + | |
| 147 | + | |
| 148 | + | |
| 149 | + | |
| 150 | + | |
| 151 | + | |
| 152 | + | |
| 153 | + | |
| 154 | + | |
| 155 | + | |
| 156 | + | |
| 157 | + | |
| 158 | + | |
| 159 | + | |
| 160 | + | |
| 161 | + | |
| 162 | + | |
| 163 | + | |
| 164 | + | |
| 165 | + | |
| 166 | + | |
| 167 | + | |
| 168 | + | |
| 169 | + | |
| 170 | + | |
| 171 | + | |
| 172 | + | |
| 173 | + | |
| 174 | + | |
| 175 | + | |
| 176 | + | |
| 177 | + | |
| 178 | + | |
| 179 | + | |
| 180 | + | |
| 181 | + | |
| 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 | + | |
| 207 | + | |
| 208 | + | |
| 209 | + | |
| 210 | + | |
| 211 | + | |
| 212 | + | |
| 213 | + | |
| 214 | + | |
| 215 | + | |
| 216 | + | |
| 217 | + | |
| 218 | + | |
| 219 | + | |
| 220 | + | |
| 221 | + | |
| 222 | + | |
| 223 | + | |
| 224 | + | |
| 225 | + | |
| 226 | + | |
| 227 | + | |
| 228 | + | |
| 229 | + | |
| 230 | + | |
| 231 | + | |
| 232 | + | |
| 233 | + | |
| 234 | + | |
| 235 | + | |
| 236 | + | |
| 237 | + | |
| 238 | + | |
| 239 | + | |
| 240 | + | |
| 241 | + | |
| 242 | + | |
| 243 | + | |
| 244 | + | |
| 245 | + | |
| 246 | + | |
| 247 | + | |
| 248 | + | |
| 249 | + | |
| 250 | + | |
| 251 | + | |
| 252 | + | |
| 253 | + | |
| 254 | + | |
126 | 255 | | |
127 | 256 | | |
128 | 257 | | |
| |||
0 commit comments