Documentation ¶
Index ¶
- Constants
- Variables
- func FormCheckRelationships(ctx context.Context, result *pkg.CheckResult) error
- func SaveResults(ctx context.Context, results []*pkg.CheckResult) ([]string, map[string]string, error)
- func ScanCanaryConfigs(ctx context.Context)
- func StartScanCanaryConfigs(ctx context.Context, dataFile string, configFiles []string)
- func SyncCanaryJob(ctx context.Context, dbCanary pkg.Canary) error
- func TriggerAt(ctx context.Context, dbCanary pkg.Canary, runAt time.Time) error
- func Unschedule(id string)
- func UpdateCanaryStatusAndEvent(ctx context.Context, canary v1.Canary, results []*pkg.CheckResult)
- type CanaryJob
- type CanaryPullResponse
- type CanaryStatusPayload
- type RelatableCheck
Constants ¶
View Source
const DefaultCanarySchedule = "@every 5m"
View Source
const ResourceTypeUpstream = "upstream"
Variables ¶
View Source
var ( ReconcilePageSize int // Only sync data created/updated in the last ReconcileMaxAge duration ReconcileMaxAge time.Duration // UpstreamConf is the global configuration for upstream UpstreamConf upstream.UpstreamConfig )
View Source
var CanaryConfigFiles []string
View Source
var CanaryLastRuntimes = sync.Map{}
View Source
var CanaryScheduler = cron.New()
View Source
var CanaryStatusChannel chan CanaryStatusPayload
View Source
var CleanupDeletedCanaryChecks = &dutyjob.Job{ Name: "CleanupChecks", Schedule: "@every 1h", Singleton: true, JobHistory: true, Retention: dutyjob.RetentionBalanced, Fn: func(ctx dutyjob.JobRuntime) error { var rows []struct { ID string } if err := ctx.DB().Raw(` SELECT DISTINCT(canaries.id) FROM canaries INNER JOIN checks ON canaries.id = checks.canary_id WHERE checks.deleted_at IS NULL AND canaries.deleted_at IS NOT NULL `).Scan(&rows).Error; err != nil { return err } for _, r := range rows { if err := db.DeleteCanary(ctx.Context, r.ID); err != nil { ctx.History.AddError(fmt.Sprintf("Error deleting components for topology[%s]: %v", r.ID, err)) } else { ctx.History.IncrSuccess() } Unschedule(r.ID) } return nil }, }
View Source
var DataFile string
View Source
var Executor bool
View Source
var FuncScheduler = cron.New()
View Source
var LogPass, LogFail bool
View Source
var MinimumTimeBetweenCanaryRuns = 10 * time.Second
View Source
var PullUpstreamCanaries = &job.Job{ Name: "PullUpstreamCanaries", JobHistory: true, Singleton: true, RunNow: true, Schedule: "@every 10m", Retention: job.RetentionFew, Fn: func(ctx job.JobRuntime) error { ctx.History.ResourceType = ResourceTypeUpstream ctx.History.ResourceID = UpstreamConf.Host count, err := pull(ctx.Context, UpstreamConf) ctx.History.SuccessCount = count return err }, }
View Source
var ReconcileCanaries = &job.Job{ Name: "ReconcileCanaries", Schedule: "@every 1m", Retention: job.RetentionBalanced, Singleton: true, JobHistory: true, RunNow: true, Fn: func(ctx job.JobRuntime) error { ctx.History.ResourceType = job.ResourceTypeUpstream ctx.History.ResourceID = UpstreamConf.Host tablesToReconcile := []string{"canaries", "checks", "check_statuses", "check_config_relationships"} summary := upstream.ReconcileSome(ctx.Context, UpstreamConf, ReconcilePageSize, tablesToReconcile...) ctx.History.AddDetails("summary", summary) ctx.History.SuccessCount, ctx.History.ErrorCount = summary.GetSuccessFailure() if summary.Error() != nil { ctx.History.AddDetails("errors", summary.Error()) } return nil }, }
View Source
var SyncCanaryJobs = &job.Job{ Name: "SyncCanaryJobs", JobHistory: true, Singleton: true, RunNow: true, Schedule: "@every 5m", Retention: job.RetentionFew, Fn: func(ctx job.JobRuntime) error { canaries, err := db.GetAllCanariesForSync(ctx.Context, runner.WatchNamespace) if err != nil { return err } ctx.Logger.V(1).Infof("syncing canary jobs for %d canaries", len(canaries)) existingIDsInCron := getAllCanaryIDsInCron() idsInNewFetch := make([]string, 0, len(canaries)) for _, c := range canaries { idsInNewFetch = append(idsInNewFetch, c.ID.String()) if err := SyncCanaryJob(ctx.Context, c); err != nil { jobHistory := models.NewJobHistory(ctx.Logger, "SyncCanary", "canary", c.ID.String()).Start() logger.Errorf("Error syncing canary[%s]: %v", c.ID, err.Error()) logIfError(jobHistory.AddError(err.Error()).End().Persist(ctx.DB()), "failed to persist job history [CanarySync]") ctx.History.AddError(err.Error()) continue } else { ctx.History.IncrSuccess() } } idsToRemoveFromCron := utils.SetDifference(existingIDsInCron, idsInNewFetch) for _, id := range idsToRemoveFromCron { Unschedule(id) } return nil }, }
View Source
var UpstreamJobs = []*job.Job{ ReconcileCanaries, PullUpstreamCanaries, }
Functions ¶
func FormCheckRelationships ¶ added in v1.0.227
func FormCheckRelationships(ctx context.Context, result *pkg.CheckResult) error
FormCheckRelationships forms check relationships with components and configs based on the lookup expressions in the check spec.
func SaveResults ¶
func ScanCanaryConfigs ¶
func StartScanCanaryConfigs ¶
func Unschedule ¶ added in v1.0.197
func Unschedule(id string)
func UpdateCanaryStatusAndEvent ¶ added in v1.0.227
Types ¶
type CanaryJob ¶
func (CanaryJob) GetNamespacedName ¶
func (j CanaryJob) GetNamespacedName() types.NamespacedName
type CanaryPullResponse ¶ added in v1.0.36
type CanaryStatusPayload ¶ added in v0.38.213
type RelatableCheck ¶ added in v1.0.129
type RelatableCheck interface {
GetRelationship() *v1.CheckRelationship
}
Click to show internal directories.
Click to hide internal directories.