This project builds a Prometheus Exporter to collect Cloudera status and usage metrics.
The dependencies are:
- GoLang >= v1.18
- github.com/prometheus/client_golang/prometheus
- github.com/tidwall/gjson gopkg.in/alecthomas/kingpin.v2
- github.com/sirupsen/logrus gopkg.in/ini.v1
This exporter scrape the metrics by independent modules (Scrapers). This modules are:
- Status: Scrapes the metrics about the current status of the Clusters, services, roles and hosts
- Hosts: Scrapes the metrics about the Hosts: CPU usage, RAM, SWAP, Agent stats and more useful metrics
- HDFS: Scrapes the metrics about HDFS: Capacity, blocks stats, file stats, Namenode properties and Snapshots.
- YARN: Scrapes the metrics about YARN: Capacity, Application running, GC.
- Impala: Scrapes the metrics about Impala: Catalog, usage stats, queries stats, state-store info …
To launch the exporter we recommend use a Docker container. Whether it is inside a container or in the local system, some Golang packages are needed as dependencies of the code to be able to implement some Prometheus functions.
Edit the config.ini file and change the host ip (cloudera_manager) in the target section by your Cloudera Manager IP addr. If you want to use "cloudera_manager" as a name-domain, edit the Makefile.common file and change "--add-host" property in the Docker_RUN_FLAGS variable.
# Compile on docker and create container
make docker_build
# Launch on docker
make docker_run
# Compile and launch
make docker
Edit the config.ini file and change the host ip (cloudera_manager) in the target section by your Cloudera Manager IP addr. If you want to use "cloudera_manager" as a name-domain, add the entry to your /etc/hosts file.
# Compile on local
make local_build
# Launch on local with Makefile
make local_run
# Launch on local on shell
./cloudera_exporter --config-file config.ini
# Compile and launch
make local
Cloudera Exporter args:
usage: cloudera_exporter [<flags>]
Flags:
-h, --help Show context-sensitive help (also try --help-long and --help-man).
--config-file="config.ini" Path to ini file.
--web.listen-address="" Listent Address.
--num-procs=0 Number Processes for parallel execution
--log-level=0 Debug Log Mode
--timeout-offset=0.25 Time to subtract from timeout in seconds.
--version Show application version.
To clean the local binary and the cloudera_exporter container
make clean
Test if cloudera_exporter is running
make test
To get a list of all the metrics of each Scraper, read the Scraper, read the METRICS_CATALOG.md file.
To contact with developers for any question or proposal read the MAINTAINERS.md file. Authors:
- Alejandro Villegas - LEAD Developer ([email protected])
- Roberto Manzano - Developer ([email protected])
- Julian Montoro - Developer ([email protected])
Former collaborators
- Raúl Barroso (Design and beta development)
Owners:
- Keedio Sistemas ([email protected])
Support:
- Support contact ([email protected])