updater,pkg/timeutil: minor cleanups

This commit is contained in:
Jimmy Zelinskie 2019-02-14 11:26:22 -05:00
parent 165c397f16
commit f64bd117b2
2 changed files with 14 additions and 10 deletions

View File

@ -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
} }
} }

View File

@ -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)