taskcluster-worker: github.com/taskcluster/taskcluster-worker/plugins/watchdog Index | Files

package watchdog

import "github.com/taskcluster/taskcluster-worker/plugins/watchdog"

Package watchdog provides a taskcluster-worker plugin that pokes a watchdog whenever a task makes progress or the worker reports that it's idle.

This serves to ensure liveness of the worker, and guard against livelocks. Often, golang will detect if the entire program deadlocks, but we can easily have a go routine working in the background while still being deadlocked.

Lack of progress on any task or lack of polling for new tasks when idle is a solid indicator that something is stuck in a livelock or deadlock. Often times a good solution is to report to sentry and kill the worker. Ideally, such bugs can be found and fixed over time.


Package Files

config.go doc.go watchdog.go

Package watchdog imports 10 packages (graph) and is imported by 1 packages. Updated 2017-04-26. Refresh now. Tools for package owners.