Prometheus Exporter for Redis metrics (Python version)
Project description
Prometheus Redis Exporter (Python версия)
Prometheus экспортер для метрик Redis/Valkey, написанный на Python.
Описание
Это Python-версия redis_exporter от oliver006, предоставляющая базовый функционал для экспорта метрик Redis в формате Prometheus.
Оригинальный проект: https://github.com/oliver006/redis_exporter
Текущий проект: https://github.com/vpuhoff/redis-exporter
Реализованные возможности
- ✅ Экспорт метрик через команду INFO
- ✅ Поддержка проверки отдельных ключей
- ✅ Поддержка паттернов ключей через SCAN
- ✅ TLS соединения
- ✅ Базовая аутентификация (username/password)
- ✅ Graceful shutdown
- ✅ Prometheus client library
Не реализовано (ограничения)
- ❌ Multi-target scrape endpoint (
/scrape) - ❌ Cluster discovery (
/discover-cluster-nodes) - ❌ Поддержка кластеров Redis
- ❌ Поддержка Sentinel
- ❌ Stream metrics
- ❌ Lua scripts
- ❌ Key groups aggregation
- ❌ Latency histograms
Требования
- Python 3.11+
- Redis 2.x - 8.x
Установка
Установка как пакет
# Из исходников
git clone https://github.com/vpuhoff/redis-exporter.git
cd redis-exporter
pip install -e .
# Или установить зависимости напрямую
pip install redis prometheus-client
Использование в вашем проекте
Если у вас уже есть Python проект с Prometheus метриками, вы можете использовать Redis Exporter как библиотеку:
from prometheus_client import REGISTRY
from exporter import RedisCollector, Options
# Создать и зарегистрировать Redis коллектор
options = Options(redis_addr="redis://localhost:6379", namespace="redis")
redis_collector = RedisCollector("redis://localhost:6379", options)
REGISTRY.register(redis_collector)
См. README_LIBRARY.md для подробных примеров интеграции в FastAPI, Flask, Django и другие фреймворки.
Использование
Базовый запуск
python main.py --redis.addr=redis://localhost:6379
С опциями
python main.py \
--redis.addr=redis://localhost:6379 \
--redis.password=mypassword \
--check-keys="db0=user:*,db1=sessions:*" \
--check-single-keys="db0=counter" \
--log-level=DEBUG
Переменные окружения
export REDIS_ADDR=redis://localhost:6379
export REDIS_PASSWORD=mypassword
export REDIS_EXPORTER_CHECK_KEYS="db0=test:*"
export REDIS_EXPORTER_LOG_LEVEL=INFO
python main.py
Docker
Сборка образа
docker build -t redis-exporter-py .
Запуск контейнера
docker run -d \
--name redis-exporter \
-p 9121:9121 \
-e REDIS_ADDR=redis://redis-host:6379 \
redis-exporter-py
Docker Compose
# Запустить тестовое окружение
docker-compose -f docker-compose-py.yml up -d
# Проверить метрики
curl http://localhost:9121/metrics
Конфигурация Prometheus
Добавьте в prometheus.yml:
scrape_configs:
- job_name: redis_exporter
static_configs:
- targets: ['localhost:9121']
Доступные флаги
| Флаг | Переменная окружения | Описание |
|---|---|---|
--redis.addr |
REDIS_ADDR |
Адрес Redis (по умолчанию: redis://localhost:6379) |
--redis.user |
REDIS_USER |
Имя пользователя для аутентификации |
--redis.password |
REDIS_PASSWORD |
Пароль для аутентификации |
--namespace |
REDIS_EXPORTER_NAMESPACE |
Namespace для метрик (по умолчанию: redis) |
--check-keys |
REDIS_EXPORTER_CHECK_KEYS |
Паттерны ключей для проверки через SCAN |
--check-single-keys |
REDIS_EXPORTER_CHECK_SINGLE_KEYS |
Конкретные ключи для проверки |
--connection-timeout |
REDIS_EXPORTER_CONNECTION_TIMEOUT |
Таймаут подключения в секундах |
--web.listen-address |
REDIS_EXPORTER_WEB_LISTEN_ADDRESS |
Адрес HTTP сервера |
--log-level |
REDIS_EXPORTER_LOG_LEVEL |
Уровень логирования (DEBUG/INFO/WARNING/ERROR) |
--log-format |
REDIS_EXPORTER_LOG_FORMAT |
Формат логов (txt/json) |
--debug |
- | Включить отладочный вывод |
--version |
- | Показать версию и выйти |
Экспортируемые метрики
Базовые метрики
redis_up- доступность Redisredis_exporter_scrapes_total- общее количество сканированийredis_exporter_scrape_duration_seconds- длительность сканированияredis_exporter_last_scrape_error- ошибка последнего сканирования
Метрики Redis INFO
Основные категории метрик из команды INFO:
- Server: uptime, процесс, потоки
- Clients: подключенные клиенты, заблокированные клиенты
- Memory: использование памяти, RSS, пиковое использование
- Stats: операции в секунду, команды
- Replication: статус репликации, offset
- Keyspace: количество ключей по БД
Метрики ключей
При использовании --check-keys или --check-single-keys:
redis_key_size- размер ключа (количество элементов)redis_key_value- значение ключа (если числовое)redis_key_value_as_string- значение ключа как строка
Примеры использования
Мониторинг одного Redis
python main.py --redis.addr=redis://localhost:6379
Мониторинг с паролем
python main.py \
--redis.addr=redis://localhost:6379 \
--redis.password=secret
Мониторинг с проверкой ключей
python main.py \
--redis.addr=redis://localhost:6379 \
--check-single-keys="db0=active_users,db0=total_sessions" \
--check-keys="db1=user:*"
TLS соединение
python main.py --redis.addr=rediss://localhost:6380
Тестирование
# Установить зависимости для разработки
uv pip install -e .
# Запустить тесты (если есть)
# pytest tests/
# Проверить метрики
curl http://localhost:9121/metrics
Разработка
Структура проекта
redis-exporter/
├── main.py # Точка входа (CLI)
├── pyproject.toml # Зависимости Python
├── Dockerfile # Docker образ
├── docker-compose.yml # Docker Compose для тестирования
├── README.md # Основная документация
├── README_LIBRARY.md # Документация для использования как библиотека
├── .gitignore # Git ignore файлы
├── LICENSE # MIT лицензия
├── exporter/ # Модули экспортера
│ ├── __init__.py
│ ├── config.py # Конфигурация
│ ├── exporter.py # Главный коллектор
│ ├── info.py # Парсинг INFO
│ ├── keys.py # Проверка ключей
│ ├── metrics.py # Вспомогательные функции
│ └── redis_client.py # Redis клиент
├── examples/ # Примеры использования как библиотеки
│ ├── __init__.py
│ ├── simple_example.py
│ ├── fastapi_example.py
│ ├── flask_example.py
│ ├── multiple_redis_example.py
│ └── custom_registry_example.py
└── contrib/ # Дополнительные материалы
├── README.md # Описание contrib
├── grafana_prometheus_redis_dashboard.json
├── grafana_prometheus_redis_dashboard_exporter_version_0.3x.json
└── k8s-redis-and-exporter-deployment.yaml
Добавление новых метрик
- Добавьте метрику в
metric_map_gaugesилиmetric_map_countersвexporter/exporter.py - Запустите тесты
- Обновите документацию
Ограничения по сравнению с Go-версией
- Одновременный мониторинг только одного Redis
- Нет поддержки кластеров
- Нет поддержки Sentinel
- Нет многопоточности для SCAN
- Более медленная работа на больших нагрузках
Использование как библиотека
Redis Exporter может использоваться в вашем Python приложении для добавления Redis метрик к существующим Prometheus метрикам:
from prometheus_client import REGISTRY
from exporter import RedisCollector, Options
# Создать и зарегистрировать коллектор
options = Options(redis_addr="redis://localhost:6379", namespace="redis")
collector = RedisCollector("redis://localhost:6379", options)
REGISTRY.register(collector)
📚 Полная документация: См. папку docs/ со всей документацией проекта.
- Быстрый старт - установка и CLI использование
- Использование как библиотека - интеграция в приложения
- Примеры - рабочие примеры использования
- Дополнительные материалы - Grafana dashboards, Kubernetes
Лицензия
MIT License - см. файл LICENSE
Благодарности
Этот проект основан на oliver006/redis_exporter.
Контрибуции
Приветствуются! Откройте issue или создайте pull request.
Поддержка
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file redis_exporter-1.0.0.tar.gz.
File metadata
- Download URL: redis_exporter-1.0.0.tar.gz
- Upload date:
- Size: 72.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
1080711ac4efcd61d0fc71886bf1c223a9c55aa62e7f93b241709bc88b4572c4
|
|
| MD5 |
66b2aaf8baf7f8970409415b91b3dae1
|
|
| BLAKE2b-256 |
a032574613aa0834934335d9b5fe676e5d92bf31de2efd49feac11775dba16ba
|
Provenance
The following attestation bundles were made for redis_exporter-1.0.0.tar.gz:
Publisher:
release.yml on vpuhoff/redis-exporter
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
redis_exporter-1.0.0.tar.gz -
Subject digest:
1080711ac4efcd61d0fc71886bf1c223a9c55aa62e7f93b241709bc88b4572c4 - Sigstore transparency entry: 659624272
- Sigstore integration time:
-
Permalink:
vpuhoff/redis-exporter@037185b723da73edbaaa1e211a685f8ed4302ed0 -
Branch / Tag:
refs/tags/1.0.0 - Owner: https://github.com/vpuhoff
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@037185b723da73edbaaa1e211a685f8ed4302ed0 -
Trigger Event:
release
-
Statement type:
File details
Details for the file redis_exporter-1.0.0-py3-none-any.whl.
File metadata
- Download URL: redis_exporter-1.0.0-py3-none-any.whl
- Upload date:
- Size: 18.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
7303aaae2094f76b41cf88437fe1e07c9843c829a22e1c69c5c6114b9886774a
|
|
| MD5 |
3416c7e239c479b0ecc7046e7934bb05
|
|
| BLAKE2b-256 |
8accd3cbd6f510e7a88cc2a44f61eea24112b5fca8f49718ade2a5f17a63d5d2
|
Provenance
The following attestation bundles were made for redis_exporter-1.0.0-py3-none-any.whl:
Publisher:
release.yml on vpuhoff/redis-exporter
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
redis_exporter-1.0.0-py3-none-any.whl -
Subject digest:
7303aaae2094f76b41cf88437fe1e07c9843c829a22e1c69c5c6114b9886774a - Sigstore transparency entry: 659624279
- Sigstore integration time:
-
Permalink:
vpuhoff/redis-exporter@037185b723da73edbaaa1e211a685f8ed4302ed0 -
Branch / Tag:
refs/tags/1.0.0 - Owner: https://github.com/vpuhoff
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@037185b723da73edbaaa1e211a685f8ed4302ed0 -
Trigger Event:
release
-
Statement type: