GithubHelp home page GithubHelp logo

staytus_exporter's Introduction

Staytus Exporter

Отдаёт в формате prometheus метрики по состоянию заведённых в staytus сервисов.

Метрики

# HELP service_status Service Status
# TYPE service_status gauge
service_status{service_permalink="web-application",service_status="ok"} 0.0
service_status{service_permalink="web-application",service_status="minor"} 1.0
service_status{service_permalink="web-application",service_status="major"} 0.0
service_status{service_permalink="web-application",service_status="maintenance"} 0.0
service_status{service_permalink="api",service_status="ok"} 0.0
service_status{service_permalink="api",service_status="minor"} 0.0
service_status{service_permalink="api",service_status="major"} 0.0
service_status{service_permalink="api",service_status="maintenance"} 1.0
service_status{service_permalink="public-website",service_status="ok"} 0.0
service_status{service_permalink="public-website",service_status="minor"} 0.0
service_status{service_permalink="public-website",service_status="major"} 1.0
service_status{service_permalink="public-website",service_status="maintenance"} 0.0
service_status{service_permalink="customer-support",service_status="ok"} 1.0
service_status{service_permalink="customer-support",service_status="minor"} 0.0
service_status{service_permalink="customer-support",service_status="major"} 0.0
service_status{service_permalink="customer-support",service_status="maintenance"} 0.0
# HELP staytus_health Staytus Health
# TYPE staytus_health gauge
staytus_health{staytus_health="healthy"} 1.0
staytus_health{staytus_health="unhealthy"} 0.0
  • service_status содержит 2 лэйбла: service_permalink (уникальный человекочитаемый идентификатор сервиса из staytus) и service_status (одно из 4х типов состояний сервиса: ok, minor, major или maintenance) в качестве значения может быть 1 (означает, что сервис service_permalink пребывает в состоянии service_status) или 0 (не пребывает в указанном состоянии);
  • staytus_health содержит лэйбл staytus_health (принимает 2 значения: healthy, если staytus нормально взаимодействует с экспортером, или unhealthy, если при взаимодействии возникают ошибки).

Конфигурация

Экспортер принимает конфигурацию через переменные окружения.

Переменная Значение по умолчанию Описание
POLLING_INTERVAL_SECONDS 2 интервал опроса staytus
EXPORTER_PORT 9877 порт, на котором отдаются метрики
STAYTUS_API_URL http://localhost:8787/ url staytus, по которому экспортер запрашивает данные о сервисах
STAYTUS_API_TOKEN - обязательный токен API staytus
STAYTUS_API_SECRET - обязательный секрет от токена
DEBUG False Включение дебажных логов (что бы включить, задать "True", "true", "1" или "yes")

Разработка

Локальная среда

Создать виртуальное окружение python:

python3 -m venv venv

Установить зависимости:

./venv/bin/python3 -m pip install -r src/requirements.txt -r tests/requirements.txt

Поднять локальный staytus:

docker-compose up

В первый раз придётся пройти wizard настройки staytus в его webUI. Какими значениями заполнять поля большого значения для целей локальной разработки не имеет. По итогу нужно обязательно выпустить токен доступа к API и забрать значение токена и его секрета.

Подготовить файл с переменными окружения:

cat .env.sample > .env

После руками вписать STAYTUS_API_TOKEN и STAYTUS_API_SECRET, которые забрали из webUI.

Перед комитом

Нижеперечисленные шаги дублируются в CI.

Проверить, что контейнер с экспортером собирается и работает

docker-compose -f docker-compose.yaml -f docker-compose.exporter.yaml up --build

Прогнать unit-тесты:

./venv/bin/python3 -m pytest tests

Отформатировать код и импорты:

./venv/bin/python3 -m isort src
./venv/bin/python3 -m black src

Проверить код pylint и mypy:

./venv/bin/python3 -m pylint src
./venv/bin/python3 -m mypy src

staytus_exporter's People

Contributors

againddm avatar

Watchers

 avatar

Forkers

fuodorov ugomon

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.