grafana

package
v1.0.16 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Jan 18, 2022 License: Apache-2.0 Imports: 20 Imported by: 0

Documentation

Index

Constants

View Source
const (
	DefaultEvaluationFrequency = "1m"
	DefaultStabilityWindow     = "0s"
)
View Source
const (
	TagRun     = "run"
	TagExit    = "exit"
	TagFailure = "failure"
)

Variables

View Source
var AnnotationTimeout = 30 * time.Second
View Source
var Assertor = regexp.MustCompile(`(?m)^(?P<reducer>\w+)\(\)\s+of\s+query\((?P<dashboardUID>\w+)\/(?P<panelID>\d+)\/(?P<metric>\w+),\s+(?P<from>\w+),\s+(?P<to>\w+)\)\s+is\s+(?P<evaluator>\w+)\((?P<params>\d*[,\s]*\d*)\)\s*(for\((?P<for>\w+)\))*\s*(every\((?P<every>\w+)\))*\s*$`)

Assertor expressions evaluated with https://regex101.com/r/xrSyEz/1

Functions

func ConvertEvaluatorAlias

func ConvertEvaluatorAlias(alias string) string

func NewGrafanaClient

func NewGrafanaClient(ctx context.Context, r logr.Logger, apiURI string, setters ...Option) error

Types

type Alert

type Alert struct {
	Metric

	TimeRange

	Query

	Execution
}

func ParseAlertExpr added in v1.0.16

func ParseAlertExpr(query v1alpha1.ExprMetrics) (*Alert, error)

type Annotation

type Annotation interface {
	// Add  pushes an annotation to grafana indicating that a new component has joined the experiment.
	Add(obj client.Object)

	// Delete pushes an annotation to grafana indicating that a new component has left the experiment.
	Delete(obj client.Object)
}

Annotation provides a way to mark points on the graph with rich events. // Conditions you hover over an annotation you can get event description and event tags. // The text field can include links to other systems with more detail.

type Client

type Client struct {
	Conn *sdk.Client
	// contains filtered or unexported fields
}
var DefaultClient *Client

func (*Client) PatchAnnotation

func (c *Client) PatchAnnotation(reqID uint, ga sdk.PatchAnnotationRequest)

PatchAnnotation updates an existing annotation to Grafana.

func (*Client) SetAlert

func (c *Client) SetAlert(alert *Alert, name string, msg string) (uint, error)

SetAlert adds a new alert to Grafana.

func (*Client) SetAnnotation

func (c *Client) SetAnnotation(ga sdk.CreateAnnotationRequest) (reqID uint)

SetAnnotation inserts a new annotation to Grafana.

func (*Client) SetNotificationChannel

func (c *Client) SetNotificationChannel(webhookPort string, cb func(b *notifier.Body)) error

func (*Client) UnsetAlert

func (c *Client) UnsetAlert(alertID string)

UnsetAlert removes an alert from Grafana.

type Execution added in v1.0.16

type Execution struct {
	Every string

	For string
}

type Metric

type Metric struct {
	DashboardUID string

	PanelID uint

	MetricName string
}

Metric points to the Grafana metric we are interested in. The location can retrieved from the Grafana URL. Example: URL: http://grafana.platform.science-hangar.eu/d/wpFnYRwGk/iperf?orgId=1&viewPanel=2 Metric: wpFnYRwGk/2/bitrate

type Option

type Option func(*Options)

func WithNotifyOnAlert

func WithNotifyOnAlert(cb func(b *notifier.Body)) Option

WithNotifyOnAlert will update the object's annotations if a Grafana alert is triggered

type Options

type Options struct {
	NotifyOnAlert func(b *notifier.Body)
}

type PointAnnotation

type PointAnnotation struct{}

func (*PointAnnotation) Add

func (a *PointAnnotation) Add(obj client.Object)

func (*PointAnnotation) Delete

func (a *PointAnnotation) Delete(obj client.Object)

type Query

type Query struct {
	/* == Evaluator
	* below
	* above
	* within_range
	* outside_range
	* empty
	 */
	Evaluator sdk.AlertEvaluator

	/* == Reducers
	* avg
	* min
	* max
	* sum
	* count
	* last
	* median
	* diff
	* diff_abs
	* percent_diff
	* percent_diff_abs
	* count_non_null
	 */
	Reducer sdk.AlertReducer
}

type RangeAnnotation

type RangeAnnotation struct {
	// contains filtered or unexported fields
}

RangeAnnotation uses range annotations to indicate the duration of a Chaos. It consists of two parts. In the first part, a failure annotation is created with open end. Conditions a new value is pushed to the timeEnd channel, the annotation is updated accordingly. TimeEnd channel can be used as many times as wished. The client is responsible to close the channel.

func (*RangeAnnotation) Add

func (a *RangeAnnotation) Add(obj client.Object, tags ...Tag)

func (*RangeAnnotation) Delete

func (a *RangeAnnotation) Delete(obj client.Object, tags ...Tag)

type Tag added in v1.0.16

type Tag = string

type TimeRange

type TimeRange struct {
	From string
	To   string
}

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL