Hidra
Hidra allows you to monitor the status of your services without headaches.
Installation
Precompiles binaries
Precompiled binaries for released versions are available in the release section on Github. Using the latest production release binary is the recommended way of installing Hidra. You can find latest release here
Docker images
Docker images are available on Github Container Registry.
Build from source
To build Hidra from source code, you need:
To build Hidra, run the following command:
goreleaser release --snapshot --rm-dist
You can find the binaries in the dist
folder.
Usage
Exporter
Hidra has support for exposing metrics to Prometheus. If you want to use Hidra in exporter mode, run:
hidra exporter /etc/hidra/exporter.yml
You can find an example of the configuration file here
Grafana
You can find a Grafana dashboard here
Test mode
Hidra has support for running in test mode. Test mode will allow you to run one time a set of samples, and check if the results are as expected. If you want to use Hidra in test mode, run:
hidra test sample1.yml sample2.yml ... samplen.yml
If you want to exit on error, just add the flag --exit-on-error
.
Sample examples
You can find some sample examples here
Docker compose
You can find an example of a docker compose file here
Samples
Samples are the way Hidra knows what to do. A sample is a YAML file that contains the information needed to run a test. You can find some sample examples here. You can also find a sample example below:
# Description of the sample
description: "This is a sample to test the HTTP plugin"
# Tags is a key-value list of tags that will be added to the sample. You can add here whatever you want.
tags:
tenant: "hidra"
# Interval is the time between each execution of the sample.
interval: "1m"
# Timeout is the time that Hidra will wait for the sample to finish.
timeout: "10s"
# Steps is a list of steps that will be executed in order.
steps:
# Plugin is the name of the plugin that will be used to execute the step.
- plugin: http
# Action is the action that will be executed by the plugin.
action: request
# Parameters is a key-value list of parameters that will be passed to the plugin.
parameters:
url: https://google.com/
- plugin: http
action: statusCodeShouldBe
parameters:
statusCode: 301
You can find more information about plugins in next section.
Plugins