This project allows you to create Test Services which are Docker containers configured to run a set of tasks, generate metrics, and push those metrics to a Prometheus Pushgateway that can later be scraped and queried by a Grafana dashboard
This project has two modes of execution: CI and local
Starting from left to right in the above diagram:
- Github Workflow files are created for each time interval Test Services should be ran
- All Test Services that should be ran for a specific time interval (e.g. 1 hour) should be defined in the same Github Workflow file
- Github will run a workflow at its specified time interval, triggering all of it's defined Test Services to run
docker-compose.ymlbuilds and runs each Test Service, setting any environment variables that can be sourced from Github secrets- Each Test Service will run its defined tasks, generate its metrics, and push them to an already deployed instance of Prometheus Pushgateway
- An already deployed instance of Prometheus will scrape the Pushgateway for metrics
- An already deployed Grafana dashboard will query Prometheus for metric data to display
Thanks to Act, Github actions can be "ran" locally for testing. Here's how:
- Install Act
- For MacOS:
brew install act
- For MacOS:
- Generate a Github access token
- I believe it only needs permission to read from repositories
- Copy secrets file:
cp .secrets.example .secretsand fill it out - Create
~/.actrcand copy the following into it:
-P ubuntu-latest=catthehacker/ubuntu:full-18.04
-P ubuntu-latest=catthehacker/ubuntu:full-18.04
-P ubuntu-18.04=catthehacker/ubuntu:full-18.04- Spin up the Pushgateway, Prometheus, and Grafana containers:
docker-compose up pushgateway prometheus grafana- Optionally, you could specify a remote Pushgateway and Prometheus instance to push metrics to in
.secretsPROMETHEUS_SERVER_URLandPROMETHEUS_PUSHGATEWAY_URL
- Optionally, you could specify a remote Pushgateway and Prometheus instance to push metrics to in
- Run
act -W .github/workflows/YOUR_WORKFLOW_FILE.yml -s GITHUB_TOKEN=YOUR_TOKEN --secret-file ./ufm-test-services/.secrets --container-architecture linux/amd64--container-architecture linux/amd64is necessary if running on MacOS, but may be different for you- Downloading the Github Actions Docker image takes a while and is pretty big, so you might need to allocate more resources to Docker, or
docker prune/remove no longer needed images/containers/volumes
Following these steps will use act to mock the Github Actions environment using a Docker container. The Github Actions container will then spin up a nested container to run each Test Service. Each Test Service should be configured to generate and push metrics to the given Pushgateway, so after act finishes execution, you should be able to login into Grafana and view the dashboards
Starting from left to right in the above diagram:
- Copy env file:
cp .env.example .envand fill it out- If you want to run local instances of the Pushgateway, Prometheus, and Grafana, you can run:
to spin those up. Otherwise, you should override the defaults URLs in the
docker-compose up pushgateway prometheus grafana
.envfor:PROMETHEUS_SERVER_URLandPROMETHEUS_PUSHGATEWAY_URL
- If you want to run local instances of the Pushgateway, Prometheus, and Grafana, you can run:
- You'll need to setup some sort of scheduler to run your Test Services at specific time intervals
- For Linux/MacOS this can be accomplished using
cron- Edit your
cronjob file usingcrontab -e - Here is some example code to get you started, also found in
crontab.examplefile:# Needs to point to docker, otherwise you'll get the error: exec: "docker": executable file not found in $PATH PATH=/ # Runs every 1 hour 0 * * * * /usr/local/bin/docker-compose -f /path/to/docker-compose.yml --profile 1hour up -d # Runs every 1 day 0 12 * * * /usr/local/bin/docker-compose -f /path/to/docker-compose.yml --profile 1day up -d # Runs every 7 days 0 12 */7 * * /usr/local/bin/docker-compose -f /path/to/docker-compose.yml --profile 7day up -d
- Edit your
- For Linux/MacOS this can be accomplished using
- Copy env file:
cp .env.example .envand fill it out - Run
docker-composefor which ever Test Service you'd like to run e.g.:docker-compose run testService1docker-compose --profile 1hour up
If you're trying to run a specific Test Service, make sure to check out their README.mds, as they may have some required prerequisites to setup before they'll run as expected