Skip to main content

A Prometheus metrics exporter for Alcatel Linkhub 4G router boxes

Project description

Linkhub Exporter

A Prometheus exporter for Alcatel Linkhub boxes.

Tested with an Alcatel HH41 4G LTE hotspot WiFi router.

Alcatel HH41 product info

Usage

Install Poetry for you system (need >=1.2.0b1 currently if using the dynamic versioning, and have to add the relevant plugin with poetry plugin add poetry-dynamic-versioning-plugin). Then install the package with:

poetry install

You'll need a Request Key to run exporter, which is derived from the login password of router box admin interface. See below how to obtain it.

Once you have a key, you can set it in multiple ways:

  • In .secrets.toml, see the template shipped at secrets.toml.template for the format (note the . for the non-template filename), OR
  • Set an environment variable LINKHUB_REQUEST_KEY with the value, e.g. export LINKHUB_REQUEST_KEY=... in your shell where ... is replaced with the actual value.

Then start up the exporter:

poetry run exporter

Running in Docker

Build the image with the included Dockerfile from the cloned repository, let's say:

docker build -t linkhub_exporter

and then run the resulting image as:

docker run -ti --rm -e "LINKHUB_REQUEST_KEY=...." -p 9877:9877 linkhub_exporter

which exposes the Prometheus metrics on http://localhost:9877. Don't forget to set the LINKHUB_REQUEST_KEY value, or add it in an .env file and run things as:

docker run -ti --rm --env-file .env -p 9877:9877 linkhub_exporter

Running in Docker Compose

You can add this exporter as a container in your docker-compose.yml, along similar lines (other container configuration has been snip'd):

  linkhub:
    image: imrehg/linkhub_prometheus_exporter
    restart: always
    ports:
      - "9877:9877"
    environment:
      - LINKHUB_EXPORTER_ADDRESS='0.0.0.0'
    env_file:
      - .env

The LINKHUB_REQUEST_KEY value should be set in the .env file (or wherever you will keep the configuration for this particular service). You can comment out the ports section if you don't want to view the results outside of the docker compose run services. You might want to add network field if you are running things within a custom network.

Finally, you probably want to set an explicit tag for the image value.

Setting up task in Prometheus

The setup in Prometheus is pretty straightforward, using the relevant IP/port combo. If the server is run manually or through Docker on its own, use the machine's IP that's running it, and the port that is set in the config. If docker compose is used, the can use the service name to connect to it automatically, say like this:

  - job_name: 'linkhub'
    scrape_interval: 5s
    static_configs:
      - targets: ['linkhub:9877']

(The other parts of the Prometheus configuration are omitted.)

Getting the request key

Currently the easiest way to get it is to:

  • Open a browser and navigate to your router admin interface
  • Open the debug console, and ensure that network requests are logged there
  • Log in to the admin interface
  • Check requests going to webapi, look for the requests headers, and the value of the _TclRequestVerificationKey is what you should use for the request key setting of this exporter.

Showing the metrics in Grafana

An example Grafana dashboard setup is provided in the extra folder.

Grafana dashboard screenshot part 1

Grafana dashboard screenshot part 2

License

Copyright 2022 Gergely Imreh gergely@imreh.net

Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at

http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

linkhub_prometheus_exporter-0.4.0.tar.gz (10.2 kB view details)

Uploaded Source

Built Distribution

File details

Details for the file linkhub_prometheus_exporter-0.4.0.tar.gz.

File metadata

  • Download URL: linkhub_prometheus_exporter-0.4.0.tar.gz
  • Upload date:
  • Size: 10.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.2.0b1 CPython/3.10.4 Linux/5.13.0-1023-azure

File hashes

Hashes for linkhub_prometheus_exporter-0.4.0.tar.gz
Algorithm Hash digest
SHA256 f491d0f95950868e996b25bf2d26be49219e5a4b245e81536e4f1c83207a9a8b
MD5 41b5216952270b8f4eb7357fe2f8f5d6
BLAKE2b-256 f1fb342b86e67c68d2a5c7f49783b53842a1c577a613860ab02d57c494a901b2

See more details on using hashes here.

File details

Details for the file linkhub_prometheus_exporter-0.4.0-py3-none-any.whl.

File metadata

File hashes

Hashes for linkhub_prometheus_exporter-0.4.0-py3-none-any.whl
Algorithm Hash digest
SHA256 efe007c1cf25c736cac7893198a1b0ee8c4e79739a8bca72218898329283ca4f
MD5 6c2103ecb46115347e3f34795fe91d39
BLAKE2b-256 8af2d09e3f7c1011052d0b9dc3d48bd915b3ca0c1f533f8dc61f89bb07984d49

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page