Commit cdf52c5
fix: Atomic job reservation to prevent race condition (#1398)
Replace the non-atomic SELECT-then-UPDATE pattern in Job.reserve()
with a single atomic UPDATE that includes status='pending' in the
WHERE clause. Check cursor.rowcount to determine if the reservation
succeeded. This eliminates the race window where multiple workers
could simultaneously reserve the same job.
The previous implementation allowed concurrent workers to both read
status='pending' and then both successfully UPDATE (since the WHERE
matched only on primary key). Now only the first UPDATE succeeds;
all others see rowcount=0 and return False.
Also reduces three database round-trips to one.
Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>1 parent 3e75a16 commit cdf52c5
1 file changed
+27
-29
lines changed| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
13 | 13 | | |
14 | 14 | | |
15 | 15 | | |
16 | | - | |
| 16 | + | |
17 | 17 | | |
18 | 18 | | |
19 | 19 | | |
| |||
431 | 431 | | |
432 | 432 | | |
433 | 433 | | |
434 | | - | |
435 | | - | |
| 434 | + | |
| 435 | + | |
| 436 | + | |
| 437 | + | |
436 | 438 | | |
437 | 439 | | |
438 | 440 | | |
| |||
444 | 446 | | |
445 | 447 | | |
446 | 448 | | |
447 | | - | |
448 | | - | |
449 | | - | |
450 | | - | |
451 | | - | |
452 | | - | |
453 | | - | |
454 | | - | |
455 | | - | |
456 | | - | |
457 | 449 | | |
458 | | - | |
459 | | - | |
460 | | - | |
461 | | - | |
462 | | - | |
463 | | - | |
464 | | - | |
465 | | - | |
466 | | - | |
467 | | - | |
468 | | - | |
469 | | - | |
470 | | - | |
471 | | - | |
472 | | - | |
473 | | - | |
| 450 | + | |
| 451 | + | |
| 452 | + | |
| 453 | + | |
| 454 | + | |
| 455 | + | |
| 456 | + | |
| 457 | + | |
| 458 | + | |
| 459 | + | |
| 460 | + | |
| 461 | + | |
| 462 | + | |
| 463 | + | |
| 464 | + | |
| 465 | + | |
| 466 | + | |
| 467 | + | |
| 468 | + | |
| 469 | + | |
| 470 | + | |
| 471 | + | |
474 | 472 | | |
475 | 473 | | |
476 | 474 | | |
| |||
0 commit comments