Commit 165b569
authored
Chore: add init exponential backoff + jitter for system_database.go (#103)
Refer to PR #101 (got closed while renaming branch)
## What this PR does
Adds exponential backoff and jitter to replace fixed delays in
system_database.go
## How it is implemented
Replaced delay interval constant by constants
```
_DB_CONNECTION_RETRY_BASE_DELAY = 500 * time.Millisecond
_DB_CONNECTION_RETRY_FACTOR = 2
_DB_CONNECTION_RETRY_MAX_RETRIES = 3
_DB_CONNECTION_MAX_DELAY = 10 * time.Second
```
Func backoffWithJitter takes an argument attempt - attempts of backoff
delay done yet.
Calculates the delay as
```
exp = baseDelay * math.Pow(retryFactor, attempts)
jitter = 0.75 + rand.Float64()*0.5 // +-25% of exp to be jitter
delay = exp * jitter
```
Capping provided against delay intervals getting too large.
If number of retries exceeds a certain limit - fallback to fixed base
delay (500ms)
Jitter added separately even for fixed intervals.
Constants may need to be changed.
## Tests
I do have a basic table driven test for this, unsure of which file to
add it in.
---------
Signed-off-by: pranshu-raj-211 <[email protected]>1 parent a84a07e commit 165b569
2 files changed
+80
-5
lines changed| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
6 | 6 | | |
7 | 7 | | |
8 | 8 | | |
| 9 | + | |
| 10 | + | |
9 | 11 | | |
10 | 12 | | |
11 | 13 | | |
| |||
140 | 142 | | |
141 | 143 | | |
142 | 144 | | |
143 | | - | |
144 | | - | |
| 145 | + | |
| 146 | + | |
| 147 | + | |
| 148 | + | |
| 149 | + | |
145 | 150 | | |
146 | 151 | | |
147 | 152 | | |
| |||
326 | 331 | | |
327 | 332 | | |
328 | 333 | | |
329 | | - | |
| 334 | + | |
330 | 335 | | |
331 | 336 | | |
332 | 337 | | |
| |||
1542 | 1547 | | |
1543 | 1548 | | |
1544 | 1549 | | |
| 1550 | + | |
1545 | 1551 | | |
1546 | 1552 | | |
1547 | 1553 | | |
| |||
1560 | 1566 | | |
1561 | 1567 | | |
1562 | 1568 | | |
1563 | | - | |
1564 | 1569 | | |
1565 | | - | |
| 1570 | + | |
| 1571 | + | |
1566 | 1572 | | |
| 1573 | + | |
| 1574 | + | |
| 1575 | + | |
| 1576 | + | |
1567 | 1577 | | |
1568 | 1578 | | |
1569 | 1579 | | |
| |||
2367 | 2377 | | |
2368 | 2378 | | |
2369 | 2379 | | |
| 2380 | + | |
| 2381 | + | |
| 2382 | + | |
| 2383 | + | |
| 2384 | + | |
| 2385 | + | |
| 2386 | + | |
| 2387 | + | |
| 2388 | + | |
| 2389 | + | |
| 2390 | + | |
| 2391 | + | |
| 2392 | + | |
| 2393 | + | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
| 2 | + | |
| 3 | + | |
| 4 | + | |
| 5 | + | |
| 6 | + | |
| 7 | + | |
| 8 | + | |
| 9 | + | |
| 10 | + | |
| 11 | + | |
| 12 | + | |
| 13 | + | |
| 14 | + | |
| 15 | + | |
| 16 | + | |
| 17 | + | |
| 18 | + | |
| 19 | + | |
| 20 | + | |
| 21 | + | |
| 22 | + | |
| 23 | + | |
| 24 | + | |
| 25 | + | |
| 26 | + | |
| 27 | + | |
| 28 | + | |
| 29 | + | |
| 30 | + | |
| 31 | + | |
| 32 | + | |
| 33 | + | |
| 34 | + | |
| 35 | + | |
| 36 | + | |
| 37 | + | |
| 38 | + | |
| 39 | + | |
| 40 | + | |
| 41 | + | |
| 42 | + | |
| 43 | + | |
| 44 | + | |
| 45 | + | |
| 46 | + | |
| 47 | + | |
| 48 | + | |
| 49 | + | |
| 50 | + | |
| 51 | + | |
0 commit comments