monitoring-indicator-protocol

module
v0.8.0 Latest Latest
Warning

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

Go to latest
Published: May 28, 2019 License: Apache-2.0

README

Monitoring Indicator Protocol

This is an observability as code project which allows developers to define and expose performance, scaling, and service level indicators for monitoring, alerting, and documentation. The indicator definition ideally lives in the same repository as the code and is automatically registered when the code is deployed.

There are 3 main uses cases for this project: Generating documentation, validating against an actual deployment's data, and keeping a registry of indicators for use in monitoring tools such as prometheus alert manager and grafana.

See the wiki for more detailed information and documentation.

Developing Locally

This project currently requires only the Go programming language to develop. Install go using brew install go, then proceed to the next steps.

Goland Setup:

  1. Preferences -> Go -> Build Tags & Vendoring -> Custom tags: -mod=vendor
  2. Preferences -> Go -> Go Modules (vgo) -> Enable Go Modules (vgo) integration
  • If the vendored import statements are still red: option + enter -> Sync packages
Running tests

Use the provided script to run tests: ./scripts/test.sh

Starting a registry and registry agent
  1. A script is provided to start both components: ./scripts/run_registry_and_agent.sh

  2. To verify that this worked, open another terminal window, and use ./scripts/curl_indicators.sh (or ./scripts/curl_indicators.sh | jq if you have access to jq)

    • Your result should look something like this:
    [
      {
        "apiVersion": "v0",
        "product": {
          "name": "my-component",
          "version": "1.2.3"
        },
        "metadata": {
          "deployment": "my-service-deployment",
          "source_id": "my-metric-source"
        },
        "indicators": [
          {
            "name": "only_in_example_yml",
            "promql": "test_query"
          },
          {
            "name": "doc_performance_indicator",
            "promql": "avg_over_time(demo_latency{source_id=\"my-metric-source\",deployment=\"my-service-deployment\"}[5m])",
            "thresholds": [
              {
                "level": "warning",
                "operator": "gte",
                "value": 50
              },
              {
                "level": "critical",
                "operator": "gt",
                "value": 100
              }
            ],
            "documentation": {
              "description": "This is a valid markdown description.\n\n**Use**: This indicates nothing. It is placeholder text.\n\n**Type**: Gauge\n**Frequency**: 60 s\n",
              "measurement": "Average latency over last 5 minutes per instance",
              "recommendedResponse": "Panic! Run around in circles flailing your arms.",
              "thresholdNote": "These are environment specific",
              "title": "Doc Performance Indicator"
            },
            "presentation": {
              "chartType": "line",
              "currentValue": false,
              "interval": "1m0s"
            }
          },
          {
            "name": "success_percentage",
            "promql": "success_percentage_promql{source_id=\"origin\"}",
            "documentation": {
              "title": "Success Percentage"
            }
          }
        ],
        "layout": {
          "title": "Monitoring Document Product",
          "description": "Document description",
          "sections": [
            {
              "title": "Indicators",
              "description": "This section includes indicators",
              "indicators": [
                "doc_performance_indicator"
              ]
            }
          ],
          "owner": "Example Team"
        }
      }
    ]
    
    

    Specifically, you should get a single product called my-component with 3 indicators, some metadata, and a layout section.

Directories

Path Synopsis
cmd
k8s
pkg/apis/indicatordocument/v1alpha1
Package v1alpha1 is the v1alpha1 version of the API.
Package v1alpha1 is the v1alpha1 version of the API.
pkg/client/clientset/versioned
This package has the automatically generated clientset.
This package has the automatically generated clientset.
pkg/client/clientset/versioned/fake
This package has the automatically generated fake clientset.
This package has the automatically generated fake clientset.
pkg/client/clientset/versioned/scheme
This package contains the scheme of the automatically generated clientset.
This package contains the scheme of the automatically generated clientset.
pkg/client/clientset/versioned/typed/indicatordocument/v1alpha1
This package has the automatically generated typed clients.
This package has the automatically generated typed clients.
pkg/client/clientset/versioned/typed/indicatordocument/v1alpha1/fake
Package fake has the automatically generated clients.
Package fake has the automatically generated clients.
pkg

Jump to

Keyboard shortcuts

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