Мониторинг ликвидности DeFi-протокола

Проектируем и разрабатываем блокчейн-решения полного цикла: от архитектуры смарт-контрактов до запуска DeFi-протоколов, NFT-маркетплейсов и криптобирж. Аудит безопасности, токеномика, интеграция с существующей инфраструктурой.
Показано 1 из 1 услугВсе 1306 услуг
Мониторинг ликвидности DeFi-протокола
Средняя
~3-5 рабочих дней
Часто задаваемые вопросы
Направления блокчейн-разработки
Этапы блокчейн-разработки
Последние работы
  • image_website-b2b-advance_0.png
    Разработка сайта компании B2B ADVANCE
    1258
  • image_web-applications_feedme_466_0.webp
    Разработка веб-приложения для компании FEEDME
    1170
  • image_websites_belfingroup_462_0.webp
    Разработка веб-сайта для компании БЕЛФИНГРУПП
    873
  • image_ecommerce_furnoro_435_0.webp
    Разработка интернет магазина для компании FURNORO
    1092
  • image_logo-advance_0.png
    Разработка логотипа компании B2B Advance
    563
  • image_crm_enviok_479_0.webp
    Разработка веб-приложения для компании Enviok
    830

Мониторинг ликвидности DeFi-протокола

Протокол с $50M TVL без мониторинга ликвидности — это не экономия на инструментах, это слепое управление риском. Когда 30% ликвидности уходит из пула за 4 часа из-за whale withdrawal, у команды есть два варианта: узнать об этом через алерт и принять меры, или узнать из твита о том, что пользователи не могут совершить своп из-за high slippage.

Что мониторить и почему это нетривиально

Концентрация ликвидности в Uniswap v3

В Uniswap v2 общая ликвидность — понятная метрика: reserve0 * reserve1 = k, чем больше k, тем лучше слиппеж. В Uniswap v3 ликвидность концентрирована по тикам. Пул может иметь $10M TVL, но если 95% сосредоточено в диапазоне ±2% от текущей цены — при выходе цены из этого диапазона effective liquidity падает в 20 раз.

Правильный мониторинг: не просто totalValueLocked, а activeLiquidity — ликвидность в активном диапазоне вокруг текущей цены. Метрика из Uniswap v3 субграфа:

query ActiveLiquidity {
  pool(id: "0x...") {
    liquidity
    sqrtPrice
    tick
    ticks(where: { liquidityNet_not: "0" }, orderBy: tickIdx) {
      tickIdx
      liquidityNet
    }
  }
}

Из этих данных строим depth chart: сколько ликвидности доступно при ±1%, ±5%, ±10% движении цены.

Whale withdrawal detection

Крупный LP может единовременно вывести ликвидность, обрушив depth на конкретном рынке. Для протокола, который зависит от ликвидности в определённых пулах (например, стейблкоин-пуле для redemption), это критический риск.

Мониторим события Burn (Uniswap v3) и RemoveLiquidity (Curve, Balancer) через WebSocket подписку. Если один LP выводит >10% от total liquidity — алерт немедленно.

Стек мониторинга

Сбор данных

Три слоя источников:

On-chain события (realtime). ethers.js WebSocket подписка на Sync, Swap, Mint, Burn события целевых контрактов. Задержка — секунды от подтверждения транзакции. Нужна собственная нода или WSS от Alchemy/Infura с поддержкой eth_subscribe.

The Graph субграфы (с задержкой 1-5 минут). Удобен для агрегированных метрик — hourly/daily TVL, volume, fees. Для исторических данных и трендов. Официальные субграфы Uniswap, Curve, Balancer, Aave, Compound доступны в The Graph Explorer.

DeFi Llama API (с задержкой 10-60 минут). Удобен для cross-protocol TVL сравнений и общей картины. Не подходит для realtime алертов.

Хранение и визуализация

TimescaleDB (PostgreSQL extension) — оптимален для time-series данных о ликвидности. Партиционирование по времени, гипертаблицы для автоматического архивирования исторических данных.

Grafana + TimescaleDB datasource — стандартный стек для дашборда. Преднастроенные панели для:

  • TVL по пулам в реальном времени
  • Depth chart (доступная ликвидность при заданном slippage)
  • Volume/liquidity ratio (индикатор стресса)
  • Top LP-провайдеры и их доля

Система алертов

Метрика Порог предупреждения Порог критический Канал
TVL drop -10% за 1 час -25% за 1 час Telegram
Single LP withdrawal >5% total liquidity >15% total liquidity PagerDuty
Slippage (1% trade) >0.5% >2% Telegram
Price deviation from oracle >2% >5% PagerDuty
Utilization (lending) >80% >95% PagerDuty

PagerDuty или OpsGenie для критических алертов — push-уведомление на телефон, независимо от времени суток. Telegram-бот для информационных уведомлений.

Tenderly Alerts — альтернатива для on-chain событий без собственной инфраструктуры: настраиваешь триггеры через UI, webhook на Discord/Slack/Telegram.

APY расчёт и мониторинг

APY в DeFi непостоянен: зависит от volume (trading fees), токен-эмиссии (liquidity mining rewards) и базовой ставки (для лендинга).

Формула для LP APY в Uniswap v3:

dailyFees = pool.volumeUSD24h * feeTier / 1_000_000
feeAPR = (dailyFees / pool.tvlUSD) * 365

При TVL $1M и дневном объёме $2M на пуле с fee 0.05% (500): dailyFees = $1000, feeAPR = 36.5%. Но это на весь TVL. LP с концентрированной позицией в активном диапазоне зарабатывает больше пропорционально своей effective liquidity.

Мониторим APY по каждому пулу с alerting при резком падении — это сигнал о снижении торговой активности или о том, что объём ушёл на конкурирующий пул.

Процесс внедрения

Инвентаризация (1 день). Список всех контрактов, событий, метрик для мониторинга. Приоритизация: что критично для работы протокола.

Настройка сбора данных (1-2 дня). WebSocket indexer на Node.js/TypeScript, запись в TimescaleDB. Для исторических данных — первичная синхронизация через The Graph.

Дашборд (1 день). Grafana с основными панелями. Не нужно делать красиво — нужно делать читаемо и с правильными временными окнами.

Алерты (1 день). Пороги на основе исторических данных протокола. Слишком чувствительные алерты — команда перестаёт на них реагировать. Начинаем с 5-6 критических метрик.

Ориентиры по срокам

Базовый мониторинг одного протокола (TVL, события, алерты) — 3-5 дней. Комплексный мониторинг нескольких протоколов с depth chart, APY трекингом и кастомным дашбордом — до 2 недель.