«Маяк у гаснущего горизонта свободного интернета»
Сквозь цифровые сумерки. Смотритель маяка, Runni
Инструмент для анализа цензуры трафика в России: обнаруживает и классифицирует блокировки сайтов, хостингов и CDN (TCP16-20 блокировки), а также подмену DNS-запросов провайдером.
Инструмент был полезен? Поставь ⭐ в качестве «спасибо»!
- TCP 16-20KB блокировка — обнаруживает обрыв соединения к CDN и хостингам после передачи 14-34KB
- Подбор белых SNI для AS хостингов/CDN
- Проверка доступности заблокированных сайтов — тестирует TLS 1.2, TLS 1.3 и HTTP
- Проверка DNS — выявляет перехват UDP/53, подмену IP-адресов заглушками и блокировку DoH
- Классификация ошибок — различает TCP RST, Connection Abort, Handshake/Read Timeout, TLS MITM, SNI-блокировку и другие
- Гибкая настройка — таймауты, потоки, свои списки доменов, DNS-серверы и IPv4-only режим
Warning
Если у вас запущены средства обхода блокировок (например, zapret или GoodbyeDPI), результаты тестов будут искажены. Чтобы узнать реальное состояние фильтров вашего провайдера, выключите их перед началом проверки или убедитесь, что они работают в режиме обработки всех пакетов (режим ALL), а не только по списку.
Следующие файлы могут быть переопределены. Инструкции ниже.
domains.txt— список доменов для проверки.tcp16.json— цели для теста TCP 16-20KB.config.yml— конфигурация.whitelist_sni.txt— список белых SNI для подбора рабочих
| Параметр | Описание | Пример использования |
|---|---|---|
-t, --tests |
Указать номера тестов (без меню). | -t 123 или -t 4 |
-p, --proxy |
Использовать прокси (переопределяет PROXY_URL). |
-p socks5://127.0.0.1:1080 |
-d, --domain |
Проверка отдельных доменов. Игнорирует domains.txt |
-d vk.com -d youtube.com |
-c, --concurrency |
Количество конкурентных запросов (переопределяет MAX_CONCURRENT). |
-c 50 |
-o, --output |
Автоматически сохранить лог в указанный файл. | -o report_log.txt |
--batch |
Отключает все вопросы и паузы в консоли. | --batch |
Docker проверит наличие обновлений и скачает свежую версию перед запуском
docker run --rm -it --pull=always ghcr.io/runnin4ik/dpi-detector:latestИли запускайте с указанием определенной версии
Это избавляет от постоянных скачиваний, но нужно следить за актуальностью версий
docker run --rm -it ghcr.io/runnin4ik/dpi-detector:3.0.1Переопределите нужные файлы: domains.txt, tcp16.json...
Запустите с монтированием (можно монтировать один или несколько файлов)
# Bash (Linux / macOS)
docker run --rm -it --pull=always \
-v $(pwd)/domains.txt:/app/domains.txt \
-v $(pwd)/tcp16.json:/app/tcp16.json \
-v $(pwd)/config.yml:/app/config.yml \
-v $(pwd)/whitelist_sni.txt:/app/whitelist_sni.txt \
ghcr.io/runnin4ik/dpi-detector:latest -t 123 -d discord.comКоманды для PowerShell и CMD
PowerShell (Windows)
docker run --rm -it --pull=always `
-v ${PWD}/domains.txt:/app/domains.txt `
-v ${PWD}/tcp16.json:/app/tcp16.json `
-v ${PWD}/config.yml:/app/config.yml `
-v ${PWD}/whitelist_sni.txt:/app/whitelist_sni.txt `
ghcr.io/runnin4ik/dpi-detector:latestCMD (Windows)
docker run --rm -it --pull=always ^
-v %cd%/domains.txt:/app/domains.txt ^
-v %cd%/tcp16.json:/app/tcp16.json ^
-v %cd%/config.yml:/app/config.yml ^
-v %cd%/whitelist_sni.txt:/app/whitelist_sni.txt ^
ghcr.io/runnin4ik/dpi-detector:latestТребования: httpx[socks]>=0.28.1, rich>=14.3.2, PyYAML>=6.0.3
Установка:
# скачайте и распакуйте архив руками, или:
git clone https://github.com/Runnin4ik/dpi-detector.git
cd dpi-detector
python -m pip install -r requirements.txtЗапуск:
python dpi_detector.py
# или с параметрами
python dpi_detector.py -t 2 -d discord.com -p socks5://127.0.0.1:1080Для использования программы не обязательно устанавливать Python. Скачайте подходящий .exe файл в разделе Releases -> Assets:
Переопределите нужные файлы: domains.txt, tcp16.json, config.yml, whitelist_sni.txt
И положите их в папку рядом с .exe файлом.
Приветствуются Issue и Pull Request'ы и предложения функционала!
MIT License — свободное использование, модификация и распространение.
Этот инструмент предназначен исключительно для образовательных и диагностических целей. Автор не несет ответственности за использование данного ПО.
- Проекту hyperion-cs/dpi-checkers за вдохновение
- 0ka за помощь и консультации
Советуем также взглянуть:
- hyperion-cs/dpi-ch — DPI comprehensive checker (go)
| Валюта | Сеть | Адрес |
|---|---|---|
| USDT | TRC20 | TGtcb4JMT5F3KiEL16oZnj9ijB2Pag1jCX |
| USDT | ERC20 | 0x97413028546b5da4cbba4d9838c9d635a5333ab1 |
| USDT | TON | UQApgV57_p0hQGBV9oxrDi7SvKqgN3pigw5YEA28VShrZ7X_ |
| TON | UQApgV57_p0hQGBV9oxrDi7SvKqgN3pigw5YEA28VShrZ7X_ |
|
| BNB | BEP-20 | 0x97413028546b5da4cbba4d9838c9d635a5333ab1 |
| SOL | 9obMiD8hYfs4D8XskQjHPPtAKYPq9CaEZTbBMxtCjQ3k |
|
| BTC | bc1q7579xpmxcrz34lzmrxfupkpcczvemeqk2e9f4h |
|
| ETH | 0x97413028546b5da4cbba4d9838c9d635a5333ab1 |
