updater,pkg/timeutil: minor cleanups
This commit is contained in:
parent
165c397f16
commit
f64bd117b2
@ -21,8 +21,9 @@ import (
|
|||||||
"math/rand"
|
"math/rand"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
"github.com/coreos/clair/pkg/stopper"
|
|
||||||
log "github.com/sirupsen/logrus"
|
log "github.com/sirupsen/logrus"
|
||||||
|
|
||||||
|
"github.com/coreos/clair/pkg/stopper"
|
||||||
)
|
)
|
||||||
|
|
||||||
// ApproxSleep is a stoppable time.Sleep that adds a slight random variation to
|
// ApproxSleep is a stoppable time.Sleep that adds a slight random variation to
|
||||||
@ -30,8 +31,9 @@ import (
|
|||||||
func ApproxSleep(approxWakeup time.Time, st *stopper.Stopper) (stopped bool) {
|
func ApproxSleep(approxWakeup time.Time, st *stopper.Stopper) (stopped bool) {
|
||||||
waitUntil := approxWakeup.Add(time.Duration(rand.ExpFloat64()/0.5) * time.Second)
|
waitUntil := approxWakeup.Add(time.Duration(rand.ExpFloat64()/0.5) * time.Second)
|
||||||
log.WithField("wakeup", waitUntil).Debug("updater sleeping")
|
log.WithField("wakeup", waitUntil).Debug("updater sleeping")
|
||||||
if !waitUntil.Before(time.Now().UTC()) {
|
now := time.Now().UTC()
|
||||||
if !st.Sleep(waitUntil.Sub(time.Now())) {
|
if !waitUntil.Before(now) {
|
||||||
|
if !st.Sleep(waitUntil.Sub(now)) {
|
||||||
return true
|
return true
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
16
updater.go
16
updater.go
@ -22,15 +22,16 @@ import (
|
|||||||
"sync"
|
"sync"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
|
"github.com/pborman/uuid"
|
||||||
|
"github.com/prometheus/client_golang/prometheus"
|
||||||
|
log "github.com/sirupsen/logrus"
|
||||||
|
"golang.org/x/sync/errgroup"
|
||||||
|
|
||||||
"github.com/coreos/clair/database"
|
"github.com/coreos/clair/database"
|
||||||
"github.com/coreos/clair/ext/vulnmdsrc"
|
"github.com/coreos/clair/ext/vulnmdsrc"
|
||||||
"github.com/coreos/clair/ext/vulnsrc"
|
"github.com/coreos/clair/ext/vulnsrc"
|
||||||
"github.com/coreos/clair/pkg/stopper"
|
"github.com/coreos/clair/pkg/stopper"
|
||||||
"github.com/coreos/clair/pkg/timeutil"
|
"github.com/coreos/clair/pkg/timeutil"
|
||||||
"github.com/pborman/uuid"
|
|
||||||
"github.com/prometheus/client_golang/prometheus"
|
|
||||||
log "github.com/sirupsen/logrus"
|
|
||||||
"golang.org/x/sync/errgroup"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
const (
|
const (
|
||||||
@ -121,7 +122,7 @@ func RunUpdater(config *UpdaterConfig, datastore database.Datastore, st *stopper
|
|||||||
|
|
||||||
// If the next update timer is in the past, then try to update.
|
// If the next update timer is in the past, then try to update.
|
||||||
if nextUpdate.Before(time.Now().UTC()) {
|
if nextUpdate.Before(time.Now().UTC()) {
|
||||||
// Attempt to get a lock on the the update.
|
// Attempt to get a lock on the update.
|
||||||
log.Debug("attempting to obtain update lock")
|
log.Debug("attempting to obtain update lock")
|
||||||
acquiredLock, lockExpiration := database.AcquireLock(datastore, updaterLockName, whoAmI, updaterLockDuration, false)
|
acquiredLock, lockExpiration := database.AcquireLock(datastore, updaterLockName, whoAmI, updaterLockDuration, false)
|
||||||
if lockExpiration.IsZero() {
|
if lockExpiration.IsZero() {
|
||||||
@ -134,6 +135,7 @@ func RunUpdater(config *UpdaterConfig, datastore database.Datastore, st *stopper
|
|||||||
sleepDuration, err = updateWhileRenewingLock(datastore, whoAmI, isFirstUpdate, st)
|
sleepDuration, err = updateWhileRenewingLock(datastore, whoAmI, isFirstUpdate, st)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
if err == errReceivedStopSignal {
|
if err == errReceivedStopSignal {
|
||||||
|
log.Debug("updater received stop signal")
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
log.WithError(err).Debug("failed to acquired lock")
|
log.WithError(err).Debug("failed to acquired lock")
|
||||||
@ -275,7 +277,7 @@ func setUpdaterDuration(start time.Time) {
|
|||||||
|
|
||||||
// fetchUpdates asynchronously runs all of the enabled Updaters, aggregates
|
// fetchUpdates asynchronously runs all of the enabled Updaters, aggregates
|
||||||
// their results, and appends metadata to the vulnerabilities found.
|
// their results, and appends metadata to the vulnerabilities found.
|
||||||
func fetchUpdates(ctx context.Context, datastore database.Datastore) (status bool, vulns []database.VulnerabilityWithAffected, flags map[string]string, notes []string) {
|
func fetchUpdates(ctx context.Context, datastore database.Datastore) (success bool, vulns []database.VulnerabilityWithAffected, flags map[string]string, notes []string) {
|
||||||
flags = make(map[string]string)
|
flags = make(map[string]string)
|
||||||
|
|
||||||
log.Info("fetching vulnerability updates")
|
log.Info("fetching vulnerability updates")
|
||||||
@ -316,7 +318,7 @@ func fetchUpdates(ctx context.Context, datastore database.Datastore) (status boo
|
|||||||
}
|
}
|
||||||
|
|
||||||
if err := g.Wait(); err == nil {
|
if err := g.Wait(); err == nil {
|
||||||
status = true
|
success = true
|
||||||
}
|
}
|
||||||
|
|
||||||
vulns = addMetadata(ctx, datastore, vulns)
|
vulns = addMetadata(ctx, datastore, vulns)
|
||||||
|
Loading…
Reference in New Issue
Block a user