
# PLC-Tracer: бесплатный браузерный визуализатор лестничной логики Allen-Bradley
🔗 GitHub: wisesokol/PLC-Tracer · v1.60 · MIT · Aleksei Sokolov, 2026
Теги: PLC Allen-Bradley ladder logic промышленная автоматизация open source Python WebSocket
Содержание
Зачем это нужно
Если вы работаете с оборудованием на базе Allen-Bradley и вам нужно разобраться в логике программы — найти, почему не срабатывает реле, почему выход не включается, какие условия заблокированы — вы сталкиваетесь с одной и той же проблемой.
Нужно дорогое лицензионное ПО.
Программа | Цена лицензии |
|---|---|
Studio 5000 (Rockwell Automation) | $3 000 — $10 000+ |
RSLogix 5000 | аналогично |
RSLinx Classic | отдельная строка бюджета |
Для крупного предприятия это рабочие расходы. Для небольшого завода, независимого сервисного инженера или специалиста в стране с ограниченным бюджетом — фактический запрет на нормальную диагностику.
Результат: инженеры работают наугад, используют пиратское ПО, тратят очень много времени чтобы разобраться в иногда огромной и сложной логике программы, прыгая по подпрограммам и рутинам в разных частях проекта. Да и есть ли человек который сможет подключиться к PLC и произвести качественную диагностику. Как показывает практика, на этом часто экономят.
PLC-Tracer создавался именно для этого сценария — бесплатный, браузерный, не требующий установки инструмент для визуализации лестничной логики Allen-Bradley в офлайн-режиме и в реальном времени. Единственная оговорка, единожды нужно сделать экспорт проекта в необходимый формат, что в принципе можно сделать и на стороне.
⚠️ Безопасность прежде всего
PLC-Tracer работает строго на чтение. Инструмент не имеет возможности записи значений или изменения логики контроллера. Bridge открывает теги через libplctag API только в режиме read. Это принципиальное архитектурное решение для безопасной работы с промышленным оборудованием.
Архитектура
Проект состоит из трёх независимых компонентов:
┌─────────────────────────────────────────────────────────┐ │ PLC-Tracer │ │ │ │ ┌──────────────────────┐ ┌────────────────────────┐ │ │ │ Ladder Visualizer │ │ Session Player │ │ │ │ plc-tracer-*.html │ │ PLC_Tracer_Player.html│ │ │ │ офлайн + онлайн │ │ воспроизведение .ndrec│ │ │ └──────────┬───────────┘ └────────────────────────┘ │ │ │ WebSocket :8765 │ │ ┌──────────┴───────────────────────────────────────┐ │ │ │ PLC Bridge │ │ │ │ plc_bridge_500.py ←→ plc_bridge_ui.py │ │ │ └──────────┬───────────────────────────────────────┘ │ └─────────────┼───────────────────────────────────────────┘ │ EtherNet/IP · PCCC · DH+ ┌────┴────┐ │ ПЛК │ SLC / MicroLogix / ControlLogix └─────────┘
Структура репозитория:
plc-tracer-500-v160.html — основной визуализатор PLC_Tracer_Player.html — плеер записей Bridge/ plc_bridge_500.py — headless Python-мост plc_bridge_ui.py — GUI-мост (Tkinter) libplctag_2.6.16_windows_x64/ — нативная DLL install.txt — инструкция по установке requirements.txt LICENSE — MIT
Модуль 1 — Ladder Visualizer
Файл: plc-tracer-500-v160.html
Один HTML-файл, никаких зависимостей, никакой сборки — открывается в любом браузере.
Поддерживаемые форматы файлов
Формат | Откуда берётся | Семейство ПЛК |
|---|---|---|
| Экспорт RSLogix 500 | SLC 5/xx, MicroLogix |
| Таблицы данных RSLogix | Офлайн-анализ переменных |
| Экспорт описаний тегов | Подписи адресов |
| Экспорт Studio 5000 | ControlLogix, CompactLogix |
Трассировка тегов
Ключевая функция визуализатора. Клик по любому тегу строит граф связанных рангов: все ранги, которые читают этот тег, и все, которые его записывают, соединяются кривыми Безье.
[Тег: B3/5] │ ├── LAD 0 / Rung 4 ──── читает ──── (XIC B3/5) ├── LAD 2 / Rung 11 ──── читает ──── (XIO B3/5) └── LAD 1 / Rung 7 ──── пишет ──── (OTE B3/5) │ └── связанные теги: N7:0, T4:2.DN ...

То, что вручную занимает 30–40 минут кросс-референсного поиска, решается за несколько секунд. История навигации Back / Forward позволяет прыгать между тегами не теряя контекст.
Живой режим (Live Mode)
При подключённом Bridge визуализатор принимает данные по WebSocket и подсвечивает ранги в реальном времени:
🟢 Зелёный — условие выполнено (
TRUE)🔴 Красный — условие не выполнено (
FALSE)
Вы видите не статическую схему, а живую картину состояния контроллера. Все таймеры тикают, все переменные, выстроенные на графе обновляются.
Запись сессий — REC
Кнопка ⏺ REC запускает запись в файл .ndrec. Формат содержит временны́е метки и значения всех отслеживаемых переменных. Запись можно передать коллеге или открыть позже в Player. Запись производится только для выстроенного графа, так что не стоит что-то добавлять на граф в режиме записи. Формат записи довольно хорошо оптимизирован и занимает мало места, возможно использование в роли регистратора для отслеживания работы оборудования.

Встроенный справочник инструкций
Полный справочник инструкций для SLC 500 и Logix 5000 прямо в интерфейсе. TON, CTU, MOV, EQU, PID, JSR — описание под рукой без открытия мануала. Оно конечно краткое, но решил что этого будет достаточно. Чтобы Help был доступен, соотвествующий файл нужно подгрузить по необходимости.
Модуль 2 — PLC Bridge
Файл: Bridge/plc_bridge_500.py
Асинхронный Python-сервис: устанавливает соединение с ПЛК и транслирует значения тегов в браузер через WebSocket на порту 8765.
Поддерживаемое оборудование
Семейство | Адресация | Протокол | Библиотека |
|---|---|---|---|
SLC 5/05 |
| ETH-PCCC | libplctag |
MicroLogix 1100 / 1200 / 1400 / 1500 | SLC-адресация | ETH-PCCC | libplctag |
ControlLogix | именованные теги | EtherNet/IP (CIP) | libplctag |
CompactLogix | именованные теги | EtherNet/IP (CIP) | libplctag |
Подключение к PLC производится через Ethernet. Поддержку RS протоколов не реализовывал, но это возможно.
Внутреннее устройство
Bridge построен на asyncio + websockets + aiohttp. Для работы с ПЛК используется нативная библиотека libplctag через ctypes — прямые вызовы DLL без дополнительных Python-обёрток.
Поддерживаемые типы данных:
INT8 · INT16 · INT32 · INT64 UINT8 · UINT16 · UINT32 · UINT32 FLOAT32 · FLOAT64 BIT STRING (Logix: LEN int32 + DATA[82] bytes) UDT (через raw bytes)
В памяти ведётся кольцевой буфер лога (500 записей) — состояние подключения видно в GUI в реальном времени.
GUI-версия (plc_bridge_ui.py) — тёмный Tkinter-интерфейс: старт / стоп / переподключение, цветовая индикация статуса, выбор папки для сохранения записей.
Поток данных
Физический ПЛК (SLC / MicroLogix / ControlLogix) │ │ EtherNet/IP · PCCC · ▼ plc_bridge_500.py ←──────► plc_bridge_ui.py (asyncio core) (Tkinter GUI) │ │ WebSocket ws://localhost:8765 ▼ PLC Tracer (браузер) live rung glow 🟢🔴
Модуль 3 — Session Player
Файл: PLC_Tracer_Player.html
Автономный плеер для воспроизведения записей .ndrec. Открывается в браузере, не требует Bridge и подключения к ПЛК.
Возможности
Функция | Описание |
|---|---|
Timeline | Цветовые дорожки ON/OFF для каждого тега |
Скорость | ×0.5 · ×1 · ×2 · ×4 · ×8 |
Шаг кадра | ← / → — покадровый разбор инцидента |
Зум | Масштабирование временно́й шкалы |
Оверлей | Состояния из записи накладываются на схему рангов |
Клавиатура |
|
Типичный сценарий: что-то произошло на линии → записали сессию → открыли в Player → прошли по кадрам → нашли момент сбоя → установили причину.
Сценарии применения
🔌 Офлайн-отладка
Экспортировать программу из RSLogix / Studio 5000 → загрузить .SLC или .L5X в визуализатор → трассировать зависимости тегов → анализировать .PRN-снимки таблиц данных (для SLC Проектов).
ПЛК и Bridge не нужны.
📡 Онлайн-мониторинг
Запустить Bridge → подключиться к ПЛК → наблюдать живую подсветку рангов → при необходимости нажать REC и записать сессию.
🔍 Разбор инцидента (Post-Mortem)
Открыть .ndrec в Player → перемотать к моменту сбоя → покадрово восстановить последовательность событий → соотнести состояния рангов с временно́й шкалой.
Установка и запуск
Требования
Python 3.10+ (добавить в PATH)
Windows (Bridge тестировался на Windows; HTML-часть кроссплатформенна)
Любой современный браузер
Bridge
# Установка зависимостей pip install -r requirements.txt # GUI-мост (рекомендуется) python Bridge/plc_bridge_ui.py
Визуализатор и Player
Просто открыть HTML-файл в браузере. Установка не нужна.
Зависимости Python
websockets aiohttp aiohttp-cors
Нативная библиотека libplctag (.dll) включена в репозиторий — отдельная установка не нужна.
Технические ограничения
Bridge тестировался на Windows x64. Для Linux потребуется скачать libplctag под целевую платформу.
Только чтение — запись значений в ПЛК не реализована намеренно.
Bridge работает локально и не требует открытия портов вовне.
HTML-часть не использует фреймворки и не требует интернета.
Для кого этот проект
🔧 Сервисные инженеры и наладчики на небольших производствах
🏭 Предприятия, которым не по карману Rockwell-лицензии
🎓 Студенты и обучающиеся в области промышленной автоматизации
🌍 Инженеры из стран, где лицензионное ПО недоступно по цене
🕵️ Все, кому нужно быстро разобраться в чужой программе без установки ПО
PLC-Tracer не претендует на замену Studio 5000. Он закрывает одну конкретную задачу: читать, понимать и диагностировать логику Allen-Bradley без финансового барьера.
Ссылки
📦 GitHub: wisesokol/PLC-Tracer
📄 Лицензия: MIT
🔗 libplctag: github.com/libplctag/libplctag (нативная библиотека, лицензируется отдельно)
Проект полностью создан с помощью Claude (Anthropic). Буду рад вопросам, замечаниям и pull request’ам.