Skip to content

Commit

Permalink
Add documentation
Browse files Browse the repository at this point in the history
  • Loading branch information
TristanCacqueray committed Nov 15, 2024
1 parent db1b7fd commit 45f21d0
Show file tree
Hide file tree
Showing 2 changed files with 15 additions and 4 deletions.
9 changes: 8 additions & 1 deletion README.md
Original file line number Diff line number Diff line change
Expand Up @@ -4,5 +4,12 @@ This is a custom prometheus exporter to provide the available capacity as a metr

```ShellSession
$ uv run ./zuul-capacity.py
usage: zuul-capacity.py [-h] --nodepool FILE
usage: zuul-capacity.py [-h] [--nodepool FILE] [--port PORT]

options:
-h, --help show this help message and exit
--nodepool FILE The list of providers
--port PORT The prometheus scrap target listening port
```

To run this service, you must provide a nodepool configuration and a clouds.yaml.
10 changes: 7 additions & 3 deletions zuul-capacity.py
Original file line number Diff line number Diff line change
@@ -1,5 +1,8 @@
# Copyright © 2024 Tristan de Cacqueray
# SPDX-License-Identifier: Apache-2.0
#
# The purpose of this script is to collect resources usage of nodepool provider.
# The metrics are available as a prometheus scrap target.

import argparse, openstack, logging, time, yaml
from dataclasses import dataclass
Expand Down Expand Up @@ -59,7 +62,8 @@ def update_providers_metric(metrics, providers):

def usage():
parser = argparse.ArgumentParser()
parser.add_argument("--nodepool", metavar="FILE", required=True)
parser.add_argument("--nodepool", metavar="FILE", default="/etc/nodepool/nodepool.yaml", help="The list of providers")
parser.add_argument("--port", type=int, default=8080, help="The prometheus scrap target listening port")
return parser.parse_args()

def main():
Expand All @@ -77,8 +81,8 @@ def main():
update_providers_metric(metrics, providers)

# Initialize connection
log.info("Starting exporter at :8080 for %d provider", len(providers))
start_http_server(8080)
log.info("Starting exporter at :%d for %d provider", args.port, len(providers))
start_http_server(args.port)

while True:
time.sleep(300)
Expand Down

0 comments on commit 45f21d0

Please sign in to comment.