There was a need to export metrics about the usage of our CI templates for KPI. This µservice will help us understand the state of our CI templates and where can it be improved.
One way this can be achieved is by exporting Prometheus metrics and create a KPI dashboard that will show the overall usage of our CI templates.
Our final ci templates KPI dashboard looks like this:
Registering a new CI job will result in the following metrics:
# HELP ci_dotnet_build_total The number of dotnet build used
# TYPE ci_dotnet_build_total counter
ci_dotnet_build_total{project="dummy-project",status="success"} 3
ci_dotnet_build_total{project="dummy-project2",status="success"} 5
ci_dotnet_build_total{project="dummy-project2",status="failed"} 12
ci_dotnet_build_total{project="dummy-project3",status="success"} 8
# HELP ci_helm_restore_duration The duration of the helm restore usage
# TYPE ci_helm_restore_duration histogram
ci_helm_restore_duration_bucket{status="success",le="60"} 60
ci_helm_restore_duration_bucket{status="success",le="120"} 67
ci_helm_restore_duration_bucket{status="success",le="300"} 68
ci_helm_restore_duration_bucket{status="success",le="600"} 72
ci_helm_restore_duration_bucket{status="success",le="900"} 74
ci_helm_restore_duration_bucket{status="success",le="1200"} 75
ci_helm_restore_duration_bucket{status="success",le="+Inf"} 76
ci_helm_restore_duration_sum_{status="success"} 7005.646230537002
-
User runs a CI job
-
Jobs scripts are completed
-
after_scriptssaves the metrics into a.jsonfile in the mounted volume -
Sidecar reads the
.jsonfile and sends it to theReceiver µservice -
The
Receiver µserviceincreases the correctmetricsof the complete job
This µservice receives HTTP requests and increases the requested metrics.
docker run -p 80:80 <image-name> receiverThis µservice waits for HTTP requests to register metrics:
curl -G -d started=2023-05-23T13:01:00Z -d status=failed -d project=dummy-project -d name=dotnet_build http://localhost:80/jobsThis will register the new CI job (if it's the first time its used) and increase it accordingly.
This µservice runs a sidecar to the build and helper containers and shares their volume mount.
exporter <file-path> <receiver-hostname>At the end of each CI job, there is an after_script that echos some variables into a .json file:
after_script:
- mkdir -p /builds/.metrics
- echo '{"started":"'"$CI_JOB_STARTED_AT"'","status":"'"CI_JOB_STATUS"'","project":"'"CI_PROJECT_PATH"'","name":"'"$CI_JOB_NAME"'"}' > /builds/.metrics/metrics.jsonThe Exporter µservice will wait for this file and then send it to the Receiver µservice which will export the metrics.
First make sure your Receiver is up and running.
Now we mimic a CI jobs usage scenario by running the curl.bash file which will mimic 5 minutes of dotnet CI usage.
- Please make sure to override the
starting-timevalue! Or all the jobs will arrive with an infinite duration.
Collect the metrics using a Prometheus instance:
Or run a new instance using:
docker run -p 9090:9090 -v path\to\prometheus.yml:/etc/prometheus/prometheus.yml prom/prometheusNext step is to connect your Prometheus instance to your Grafana and create a dashboard:
Or run a new Grafana instance by:
docker run -d --name=grafana -p 3000:3000 grafana/grafanaGeneral information about the usage generally.
Information about each CI job.
