@ -29,7 +29,6 @@ import (
const (
const (
bgHealingUUID = "0000-0000-0000-0000"
bgHealingUUID = "0000-0000-0000-0000"
leaderTick = time . Hour
leaderTick = time . Hour
healTick = time . Hour
healInterval = 30 * 24 * time . Hour
healInterval = 30 * 24 * time . Hour
)
)
@ -75,6 +74,7 @@ func getLocalBackgroundHealStatus() madmin.BgHealState {
return madmin . BgHealState {
return madmin . BgHealState {
ScannedItemsCount : bgSeq . scannedItemsCount ,
ScannedItemsCount : bgSeq . scannedItemsCount ,
LastHealActivity : bgSeq . lastHealActivity ,
LastHealActivity : bgSeq . lastHealActivity ,
NextHealRound : UTCNow ( ) . Add ( durationToNextHealRound ( bgSeq . lastHealActivity ) ) ,
}
}
}
}
@ -112,6 +112,19 @@ func healErasureSet(ctx context.Context, setIndex int, xlObj *xlObjects) error {
return nil
return nil
}
}
// Returns the duration to the next background healing round
func durationToNextHealRound ( lastHeal time . Time ) time . Duration {
if lastHeal . IsZero ( ) {
lastHeal = globalBootTime
}
d := lastHeal . Add ( healInterval ) . Sub ( UTCNow ( ) )
if d < 0 {
return time . Second
}
return d
}
// Healing leader will take the charge of healing all erasure sets
// Healing leader will take the charge of healing all erasure sets
func execLeaderTasks ( z * xlZones ) {
func execLeaderTasks ( z * xlZones ) {
ctx := context . Background ( )
ctx := context . Background ( )
@ -132,10 +145,7 @@ func execLeaderTasks(z *xlZones) {
lastScanTime := time . Now ( ) // So that we don't heal immediately, but after one month.
lastScanTime := time . Now ( ) // So that we don't heal immediately, but after one month.
for {
for {
if time . Since ( lastScanTime ) < healInterval {
time . Sleep ( durationToNextHealRound ( lastScanTime ) )
time . Sleep ( healTick )
continue
}
for _ , zone := range z . zones {
for _ , zone := range z . zones {
// Heal set by set
// Heal set by set
for i , set := range zone . sets {
for i , set := range zone . sets {