Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/grafana/synthetic-monitoring-app

Synthetic Monitoring frontend application
https://github.com/grafana/synthetic-monitoring-app

grafana grafana-synthetic-monitoring monitoring synthetic-monitoring

Last synced: about 15 hours ago
JSON representation

Synthetic Monitoring frontend application

Awesome Lists containing this project

README

        

# Synthetic monitoring application

Synthetic Monitoring is a blackbox monitoring solution provided as part of [Grafana Cloud](https://grafana.com/products/cloud/).
Synthetic Monitoring provides users with insights into how their applications and services are behaving from an external point of view.
Users can define checks to continually test remote targets from 1 or more probe locations around the world to assess the availability, performance and correctness of the services. As each check runs, metrics and logs are collected and published to the user's Grafana Cloud service. Metrics are published to Grafana Cloud Prometheus and logs are published to Grafana Cloud Loki.

Synthetic monitoring is the successor to the original [worldping application](https://github.com/raintank/worldping-app).
The refreshed Synthetic Monitoring product focuses on reducing complexity and taking advantage of Grafana Cloud capabilities.

### Check Types

Users can define HTTP/HTTPS, DNS, TCP and ICMP Ping checks to monitor their remote targets. Internally, the Synthetic Monitoring solution uses the [Prometheus Blackbox exporter](https://github.com/prometheus/blackbox_exporter) for executing the checks and collecting metrics and logs. When creating a check, users are able to customize the settings and validation rules supported by the Blackbox exporter.

### Probe Locations

For each check, users can select 1 or more 'public' probe locations distributed throughout the world to run tests from. Additionally, users can run their own 'private' probe locations by downloading and deploying the [Synthetic Monitoring Agent](https://github.com/grafana/synthetic-monitoring-agent).

### Configuration

Synthetic Monitoring requires a Grafana Cloud account, and is installed by default in Grafana Cloud stacks. A local Grafana instance can be configured to connect to Synthetic Monitoring via a [provisioning file](https://grafana.com/docs/grafana/latest/administration/provisioning/#plugins):

```yaml
apiVersion: 1

apps:
- type: grafana-synthetic-monitoring-app
name: grafana-synthetic-monitoring-app
disabled: false
jsonData:
apiHost:
stackId:
logs:
grafanaName:
hostedId:
metrics:
grafanaName:
hostedId:
secureJsonData:
publisherToken:
```

Configuration details:

- `apiHost` expects Synthetic Monitoring API URL, [see more details here](https://github.com/grafana/synthetic-monitoring-api-go-client/blob/main/docs/API.md#api-url)

- `stackId` expects an integer and can be found using `gcom /instances/`, or by visiting `https://grafana.com/orgs//stacks` and clicking the `details` button on stack you are connecting to. The id will be in the URL.
- The `logs` and `metrics` section are instructing the plugin which datasources it needs to use.
- The `grafanaName` needs to exactly match the names specified in your datasource provisioning
- The `hostedId` expects an integer and is the same value as the `basicAuthUser` in your datasource provisioning. The value can also be found from the `details` page of loki or prometheus at `https://grafana.com/orgs//stacks`.
- `publisherToken` is an access policy token used to communicate with your Cloud stack and publish telemetry data from the probes. The access policy needs to have the following scopes:
- Read stacks
- Write metrics
- Write logs
- Write traces

Note: you can add a provisioning block per [org](https://grafana.com/docs/grafana/latest/manage-users/server-admin/server-admin-manage-orgs/) to provision the plugin for multiple orgs. You can provide different values for each org block and connect to a different cloud stack per org.

Prerequisites:

1. A datasource pointed at a Prometheus instance hosted in Grafana Cloud
2. A datasource pointed at a Loki instance hosted in Grafana Cloud

**Note: The Prometheus and Loki instances must be part of the same Cloud stack**

The required datasources can be [added via provisioning](https://grafana.com/docs/grafana/latest/administration/provisioning/#data-sources). The information needed can be copied from Prometheus and Loki datasources found in the datasources tab of a Cloud hosted Grafana instance:

```yaml
apiVersion: 1

datasources:
- name:
type: loki
access: proxy
url: https://logs-prod-us-central1.grafana.net
basicAuth: true
basicAuthUser:
jsonData:
maxLines: 1000
secureJsonData:
basicAuthPassword:
version: 1

- name:
type: prometheus
access: proxy
url: https://prometheus-us-central1.grafana.net/api/prom
basicAuth: true
basicAuthUser:
jsonData:
timeInterval: 1s
secureJsonData:
basicAuthPassword:
version: 1
```

To run the local environment:

1. Start the frontend build: `yarn dev`
2. Start Grafana: `yarn server`
3. Grafana will be available at `localhost:3000`

To start the using app:

1. Navigate to Synthetic Monitoring via the sidebar
2. Click the **Get Started** button. This will initialize the app.

During the Initialization process, the Synthetic Monitoring backend will:

1. Validate the Publisher API key provided in the provisioning file.
2. Ensure the account has active Grafana Cloud Prometheus and Grafana Cloud Loki services
3. The dashboards included with the App will then be imported.
4. Finally, the Synthentic Monitoring Backend will be notified that the service is ready.

Users can then create checks to monitor their remote targets. Metrics and logs will flow into the selected Cloud stack.