mirror of
https://github.com/mattermost/mattermost.git
synced 2026-02-03 20:40:00 -05:00
Include https://github.com/mattermost/mattermost-plugin-api into the mono repo Co-authored-by: Jesse Hallam <jesse.hallam@gmail.com> Co-authored-by: Michael Kochell <mjkochell@gmail.com> Co-authored-by: Alejandro García Montoro <alejandro.garciamontoro@gmail.com> Co-authored-by: Ben Schumacher <ben.schumacher@mattermost.com> Co-authored-by: Alex Dovenmuehle <alex.dovenmuehle@mattermost.com> Co-authored-by: Michael Kochell <6913320+mickmister@users.noreply.github.com> Co-authored-by: Christopher Poile <cpoile@gmail.com> Co-authored-by: İlker Göktuğ Öztürk <ilkergoktugozturk@gmail.com> Co-authored-by: Shota Gvinepadze <wineson@gmail.com> Co-authored-by: Ali Farooq <ali.farooq0@pm.me> Co-authored-by: Maria A Nunez <maria.nunez@mattermost.com> Co-authored-by: Daniel Espino García <larkox@gmail.com> Co-authored-by: Christopher Speller <crspeller@gmail.com> Co-authored-by: Alex Dovenmuehle <adovenmuehle@gmail.com> Co-authored-by: Szymon Gibała <szymongib@gmail.com> Co-authored-by: Lev <1187448+levb@users.noreply.github.com> Co-authored-by: Jason Frerich <jason.frerich@mattermost.com> Co-authored-by: Agniva De Sarker <agnivade@yahoo.co.in> Co-authored-by: Artur M. Wolff <artur.m.wolff@gmail.com> Co-authored-by: Madhav Hugar <16546715+madhavhugar@users.noreply.github.com> Co-authored-by: Joe <security.joe@pm.me> Co-authored-by: Ibrahim Serdar Acikgoz <serdaracikgoz86@gmail.com> Co-authored-by: José Peso <trilopin@users.noreply.github.com>
43 lines
1.2 KiB
Go
43 lines
1.2 KiB
Go
package cluster
|
|
|
|
import (
|
|
"math/rand"
|
|
"time"
|
|
)
|
|
|
|
const (
|
|
// minWaitInterval is the minimum amount of time to wait between locking attempts
|
|
minWaitInterval = 1 * time.Second
|
|
|
|
// maxWaitInterval is the maximum amount of time to wait between locking attempts
|
|
maxWaitInterval = 5 * time.Minute
|
|
|
|
// pollWaitInterval is the usual time to wait between unsuccessful locking attempts
|
|
pollWaitInterval = 1 * time.Second
|
|
|
|
// jitterWaitInterval is the amount of jitter to add when waiting to avoid thundering herds
|
|
jitterWaitInterval = minWaitInterval / 2
|
|
)
|
|
|
|
// nextWaitInterval determines how long to wait until the next lock retry.
|
|
func nextWaitInterval(lastWaitInterval time.Duration, err error) time.Duration {
|
|
nextWaitInterval := lastWaitInterval
|
|
|
|
if nextWaitInterval <= 0 {
|
|
nextWaitInterval = minWaitInterval
|
|
}
|
|
|
|
if err != nil {
|
|
nextWaitInterval *= 2
|
|
if nextWaitInterval > maxWaitInterval {
|
|
nextWaitInterval = maxWaitInterval
|
|
}
|
|
} else {
|
|
nextWaitInterval = pollWaitInterval
|
|
}
|
|
|
|
// Add some jitter to avoid unnecessary collision between competing plugin instances.
|
|
nextWaitInterval += time.Duration(rand.Int63n(int64(jitterWaitInterval)) - int64(jitterWaitInterval)/2)
|
|
|
|
return nextWaitInterval
|
|
}
|