惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

F
Full Disclosure
Recorded Future
Recorded Future
T
Tenable Blog
S
Securelist
C
CERT Recently Published Vulnerability Notes
T
Threatpost
S
Schneier on Security
A
Arctic Wolf
The Hacker News
The Hacker News
C
CXSECURITY Database RSS Feed - CXSecurity.com
Know Your Adversary
Know Your Adversary
P
Privacy International News Feed
Threat Intelligence Blog | Flashpoint
Threat Intelligence Blog | Flashpoint
The Register - Security
The Register - Security
Cisco Talos Blog
Cisco Talos Blog
AWS News Blog
AWS News Blog
K
Kaspersky official blog
T
True Tiger Recordings
T
Threat Research - Cisco Blogs
V
Vulnerabilities – Threatpost
P
Palo Alto Networks Blog
T
The Exploit Database - CXSecurity.com
小众软件
小众软件
B
Blog
Cyber Security Advisories - MS-ISAC
Cyber Security Advisories - MS-ISAC
Microsoft Azure Blog
Microsoft Azure Blog
Cyberwarzone
Cyberwarzone
C
Cybersecurity and Infrastructure Security Agency CISA
T
Tor Project blog
Spread Privacy
Spread Privacy
Malwarebytes
Malwarebytes
P
Proofpoint News Feed
F
Fox-IT International blog
F
Fortinet All Blogs
P
Privacy & Cybersecurity Law Blog
G
GRAHAM CLULEY
量子位
Latest news
Latest news
OSCHINA 社区最新新闻
OSCHINA 社区最新新闻
博客园 - 叶小钗
Project Zero
Project Zero
T
Tailwind CSS Blog
N
Netflix TechBlog - Medium
Martin Fowler
Martin Fowler
IntelliJ IDEA : IntelliJ IDEA – the Leading IDE for Professional Development in Java and Kotlin | The JetBrains Blog
IntelliJ IDEA : IntelliJ IDEA – the Leading IDE for Professional Development in Java and Kotlin | The JetBrains Blog
I
Intezer
博客园_首页
腾讯CDC
H
Hackread – Cybersecurity News, Data Breaches, AI and More
D
Darknet – Hacking Tools, Hacker News & Cyber Security

Все публикации подряд на Хабре

256 зелёных тестов на нерабочем коде. Так выглядит «услужливый клерк» внутри нейросети Бизнес-аналитика для сети из 300 аптек: прогноз продаж и другие показатели Impact Analysis в дизайн-системе: как мы сделали CI осмысленнее, а review понятнее Топ-5 лучших нейросетей 2026 года: полный список на любой случай в SpeShu.AI Что делает сотрудников по-настоящему эффективными: процессы, знания или технологии Как за один вечер я написал сервис инвентаризации оргтехники для филиальной сети из 16 локаций Склад нанимает — и не может остановиться. Дефицит складских работников в 2026 году: причины и решения Шёл за утечкой памяти, нашёл утечку диска: SXSSFWorkbook без dispose() в Apache POI Штраф в размере 155 000 рублей получил владелец сайта по заявлению Роскомнадзора Индивидуальный план развития: от формальной процедуры к инструменту управления экспертизой команды Как понять, что вы не управляете финансами, а просто смотрите на цифры Водоросли и микропластик Масштабирование LLM: от одного чипа до ЦОДа. Глава 3. Траснформеры Бомба замедленного действия взорвалась: эпоха ИИ «бери сколько унесёшь» закончилась Стимпанк как часть жизни. История паровых двигателей и место, которое они занимали в мире в XIX-XX веках. Часть 2 288-ядерный Xeon 6+ и другие серверные CPU От OCR к смыслу: как мы научили модель понимать, кто кому отец, мать, жених и свидетель Насколько плох был Intel iAPX 432 — проверяем на практике Приручаем железо: внедряем DevOps в промышленной разработке Когда Reality не хватает: добавляем Hysteria2 + Salamander в iOS-мессенджер, и как всегда грабли по дороге (ч.2) Дайджест C++: новости, полезные материалы и “свой язык” на десерт Ещё один репозиторий моделей для Archi 10 простых шагов, чтобы создать позиционирование для продукта Загадочная поэма древнего Китая, работающая как компьютер CLOUD Act, GDPR и ваш DNS: что на самом деле может ваш провайдер Ускоряем и оптимизируем numpy, pandas, scipy и sklearn Idempotency keys: 5 граблей, которые мы поймали на проде Gamedev. Парсинг данных из Google Sheets и Excel в json без привлечения программистов Nano Banana Google AI: как использовать Нано Банана для генерации и редактирования изображений Два игрока на весь российский рынок ИИ: что показал ЦИПР-2026 Менеджер ресурсов ЯНДЕКС 360 (YANDEX 360) промокоды июнь 2026: промокод Yandex 360 скидка 40% на годовые тарифы Open-Source инструмент для автоматического перевода книг Ищу ранних тестировщиков для Android-версии agent harnesses Не используйте LLM для текста Увеличиваем продажи без слез аналитика Оптимизация запросов к PostgreSQL: 5 неочевидных настроек для продакшена 45 лет тюрьмы за DROP TABLE и переход Карпатого в Anthropic Планирование движения для ровера на ходовой Ackerman'а Революция в изучении языков Java — быстрая. Ваш код может таким не быть Как я опоздал на конкурс OpenAi с новой архитектурой нейросети Быстрые интеграции в 1С: прощайте, бесконечные переделки Как получить субсидию 300 миллионов от Минпромторга? preIPO Anthropic, OpenAI, SpaceX. Разбираемся — стоит ли участвовать? Entaxy ION + OPC UA: два способа получить данные с промышленного оборудования Память на миллион, а толку ноль: как мы спасали ИИ-агента от «тупости» РСЯ, AdSense или myTarget: что на самом деле в 2026 приносит больше денег сайту и причем тут монетизаторы Практическое построение сервисов на Go под реальный трафик PostgreSQL и аналитика: что меняется, когда хранилище становится общим Codex за 5 месяцев 2026: мой топ-5 релизов, что не зашло и где OpenAI обогнал Anthropic Как создать короткое видео с помощью нейросетей: Полный гайд по Veo 3.1, Kling 3.0 и Happy Horse 1.0 Алгоритм проверок физлиц от экс сотрудника ФНС Как ИИ портит резюме студентам Системные вызовы в сфере ИТ в 2026: стратегический взгляд для ИТ-руководителей Вайбкодинг заканчивается на localhost: как я строю SaaS для цифровизации коттеджных поселков с Codex Производственные риски в небольшом кастомном производстве. С чем я сталкивалась и как научилась это учитывать Подключаем ИИ органы чувств: bash-демон, пайка и самосознание на Raspberry Pi Я хотел повторить Growing Neural CA за вечер. Ушёл месяц Промт для генерации текста без ИИ следа — как писать уникальные тексты через нейросеть От capabilities к AppArmor: что реально остановит атакующего в контейнере CactOS Вектора интересов: как находить настоящую мотивацию и усиливать команды Цена безопасности [Перевод] Цена безопасности “Рубик” от пет-проекта до прода или ITIL 4 для строительно-торговых центров Чего ждать (и не ждать) от ремейка AC4 Black Flag Архитектурный тупик корпоративного хранения: почему смена модели не снимает ограничений и что с этим делать Атаки через подрядчиков, дефицит кадров и квест с импортозамещением: главные вызовы ИБ в 2026 году Я не оставлю детям наследства Почему порты стали «дверями» в сервер, и кто решил, что SSH будет 22 Почему зарубежные разработчики чипов возвращаются на китайские фабрики Как у меня НЕ получился торговый бот на Polymarket Проектирование архитектуры в нотации ArchiMate с использованием ИИ. Часть 2 Как превратить домашнюю файлопомойку в умную AI-галерею на основе сборки из x99+Xeon и видеокарты за 2 тыс рублей Перспективы заселения нашей галактики Кризис менеджмент в ИТ Reactive Programming не спасёт вас. Если вы не решили эти 5 проблем — у вас просто медленный монолит с Flux Как я делаю DIY-контроллер для ПК: громкость, приложения, MIDI, OBS Миграция микросервисов на Python с помощью LLM: экономим месяцы для разработчиков Программирование микросхем GAL и им подобных Почему таск-трекер не заменяет ИСУП: из чего состоит полноценный контур управления проектами Всё об информационной безопасности. Кибербезопасность. DevOps, CI/CD. Хакеры. Алексей Федулаев Как импортировать базу клиентов в amoCRM и навести порядок в контактах Как мы четыре раза переписали Outbox Google предлагает единый «водяной знак» для изображений, видео и текста, созданных ИИ Сексизм в IT: данные вместо домыслов Один фронтенд, чтоб править всеми, один фронтенд, чтоб всех найти: 1 точка входа, разные BI ИИ в тестировании: зачем мы пошли в пилот и почему начали с чата, а не с агентов Как я научила Telegram-бота наводить порядок в чате с мемами: пересылка по хештегам в соответствующую тему Как мы сделали внутреннюю CRM для управления студией – опыт Doubletapp Десятипальцевый метод — как печатать цифру " Шесть "? Партнерская программа по нейросетям: зарабатывай на ИИ, приводя клиентов в AI-сервис Как я сделал «клик по элементу → открыть в VS Code» за один вечер Эволюция Telegram‑бота на C++: от «лапши» в main() до ООП, in‑memory кэша и мутов по Фибоначчи Как я (внезапно) стал адвокатом вайб‑кодинга в корпорации Дизайн за 5 минут. Дайджест мая 2026 Только 17% всех 64-битных целых чисел можно разложить на два 32-битных 0,000000001% × ∞ = 100%. Вы осознаёте что любое событие неизбежно? «Вы либо трусы наденьте, либо крестик снимите». Как мы выиграли еще один суд против PR-агентства PRslon
Разработчики не экстрасенсы: как мы перестали приносить туман вместо ТЗ
Engel_Adylev · 2026-05-27 · via Все публикации подряд на Хабре

Разработчики не экстрасенсы: как мы перестали приносить туман вместо ТЗ

Уровень сложностиПростой

Время на прочтение8 мин

Охват и читатели3.5K

Кейс

Кейс про вагоны, Claude и то, зачем аналитику иногда полезно «потрогать» будущую систему до разработки. Это не история о том, как ИИ заменил разработчиков. Скорее наоборот: это история о том, как аналитикам перестать приносить разработчикам красивый документ, внутри которого всё ещё туман.

Хотим видеть, где наши вагоны, и оставлять к ним комментарии.

Требование звучало почти безобидно. На первый взгляд — обычная задача для отчёта. Есть поток дислокации, есть номера вагонов, станции, остаток пути, номер поезда. Показываем всё в таблице, добавляем фильтры, рядом поле для комментария — готово.

Мы так и начали: собрали витрину в Apache Superset на живых данных.

Выглядело нормально. Даже красиво.

Рисунок 1. Первая версия в Superset: дашборд с данными по вагонам и поездам. Он помог быстро увидеть картину, но не решал главную задачу — работу с рейсами, накладными, комментариями и приёмкой. Этот экран был полезен как разведка данных, но слаб как рабочий инструмент оператора.

Рисунок 1. Первая версия в Superset: дашборд с данными по вагонам и поездам. Он помог быстро увидеть картину, но не решал главную задачу — работу с рейсами, накладными, комментариями и приёмкой. Этот экран был полезен как разведка данных, но слаб как рабочий инструмент оператора.

Через несколько обсуждений стало ясно: бизнесу нужен не отчёт. Бизнесу нужна система. Отчёт показывает данные. Система помогает работать. Это разные вещи. Оператору нужно не просто увидеть вагон, а понять, что с ним происходит. Оставить комментарий не «на номер вагона вообще», а на конкретную ситуацию. Подготовить приёмку. Связать вагон с накладной. Разобраться, почему вагон в одном составе, потом в другом. Передать итоговые данные дальше в учётную систему.

И вот тут простая фраза «видеть вагоны» начала разворачиваться в предметную область.

  • Вагон — не всегда просто вагон

Один и тот же физический вагон может приезжать несколько раз за год. Значит, нужен не только вагон, но и рейс вагона.

  • Поезд — не фундамент модели

Вагоны могут отцепляться, прицепляться и менять состав. Поезд удобен для экрана, но опасен как главный ключ.

  • Дислокация — это поток

Данные приходят событиями: операция, станция, время, остаток пути, номер поезда. Это не статичная таблица.

  • ЭТРАН приносит не только пользу

Накладные дают данные о грузе и контейнерах, но вместе с ними приходят грязные номера, плейсхолдеры и неоднозначные связи. Так из одной фразы выросла система с рейсами, статусами, комментариями, ЭТРАН-накладными, синхронизацией и подготовкой данных для 1С.


«А что должно быть, если?..» — момент, когда ТЗ начинает трещать

В IT есть знакомая сцена. Аналитик приносит ТЗ. Вроде всё написано: поля, кнопки, фильтры, статусы, комментарии.

Разработчик открывает документ и начинает задавать вопросы:

  • комментарий относится к вагону или к рейсу?

  • что делать, если этот вагон уже был в системе месяц назад?

  • поезд может измениться по пути?

  • что считать прибытием?

  • если накладная пришла с мусорным номером вагона — мы её теряем или

  • отправляем на ручной разбор?

  • кто источник истины: дислокация, ЭТРАН, оператор или 1С?

Т И П И Ч Н А Я С Ц Е Н А

Аналитику кажется, что разработчик душнит. Разработчику кажется, что ему снова принесли текст, который выглядит как ТЗ, но не отвечает на инженерные вопросы. Бизнесу кажется, что команда тормозит на очевидной задаче. Хотя чаще всего проблема не в людях.

Проблема в том, что все слишком поздно проверили, одинаковую ли систему они представляют.

Бизнес думает результатом: «хочу видеть вагоны».

Аналитик часто фиксирует процесс: «пользователь видит список, фильтрует, комментирует». Разработчик вынужден думать моделью: сущности, связи, ключи, статусы, переходы, ошибки, грязные данные, транзакции, история, права, интеграции.

Между бизнесовой фразой и задачей для разработки есть пустая зона. Если аналитик не пройдёт её раньше, её всё равно придётся проходить — только уже дороже.

Нам хотелось пройти эту зону до разработки. Для этого мы использовали Claude не как «автопрограммиста», а как черновой инженерный стенд для аналитика.

Как мы работали с Claude на самом деле

Самый плохой способ использовать ИИ в такой задаче — написать:

Сделай систему слежения за вагонами.

Так можно быстро получить уверенный набор файлов, который выглядит как проект, но слабо связан с реальностью.

Мы работали иначе.

  1. Сначала описывали контекст: откуда приходят вагоны, какие данные отдаёт РЖД, кто сидит за экраном и где заканчивается внешний мониторинг.

  2. Потом раскладывали предметную область: физический вагон, рейс, событие дислокации, поезд как временная группировка, комментарий, накладная, заявка на приёмку.

  3. Дальше проверяли сценарии на живых данных: перецепка, повторный приезд, грязный номер, пустая дата, изменение остатка пути, завершение рейса.

  4. После этого собирали черновую модель: таблицы, связи, статусы, API, экран оператора и правила синхронизации.

Claude помогал быстро материализовать гипотезы: предложить модель, набросать таблицы, сформулировать API, собрать черновой экран, показать слабые места.

Но самые ценные моменты были не там, где он писал код.

Самые ценные моменты были там, где становилось видно: наша собственная формулировка задачи неполная.

В этот момент ИИ перестаёт быть «генератором кода» и становится зеркалом для требований. Не всегда умным. Не всегда точным. Но достаточно быстрым, чтобы заставить аналитика раньше столкнуться с реальностью системы.

Что вскрыл прототип

1. Вагон и рейс — разные сущности

Бизнес говорит «вагон». Но система должна понимать: речь о физическом объекте или о конкретной поездке?

Если привязать комментарии, статусы и накладные просто к номеру вагона, история быстро смешается. Вагон может приехать снова, а старые комментарии и состояния начнут жить рядом с новым процессом.

wagon → wagon_trip → dislocation_event

Физический вагон отвечает на вопрос: «что это за объект?» Рейс отвечает на вопрос: «какая это конкретная поездка?» Событие отвечает на вопрос: «что произошло с ним во времени?»

Т Е Х Н И Ч Е С К А Я В С ТА В К А : М О Д Е Л Ь

Когда мы разобрали это разделение, модель выстроилась сама:

wagons — физический объект: номер, тип, владелец

└─ wagon_trips — один рейс: вагон + дата + станция отправления

└─ dislocation_events — поток событий: операция, станция, время

Ключ рейса: (вагон, бизнес-дата в МСК, станция отправления) Комментарии → wagon_trip_id | Накладные → trip_waybills(wagon_trip_id, waybill_id)

2. Поезд удобен на экране, но опасен в модели

Оператору удобно видеть вагоны по поездам. Это естественная группировка. Но поезд в живых данных нестабилен: вагоны могут менять составы по пути. Если сделать поезд главным контейнером процесса, при перецепке начнут ломаться история, статусы и связи.

3. Дислокация — это поток, а не «последняя строка»

Самая большая сложность оказалась в синхронизации. На уровне отчёта всё выглядело просто: взять последнее событие по вагону. Но для рабочей системы этого недостаточно. Синхронизация превратилась в 8-шаговый конвейер:

  1. Отбор релевантных вагонов из потока

  2. Создание или обновление активных рейсов

  3. Привязка новых операций РЖД к рейсам

  4. Обновление текущего состояния рейса для интерфейса

  5. Сопоставление рейсов с накладными ЭТРАН

  6. Закрытие рейсов по терминальным событиям

  7. Реактивация ошибочно закрытых рейсов

  8. Нормализация активных рейсов и связей

На прототипе мы увидели, что синхронизация — это отдельная предметная задача, а не вспомогательный скрипт.

4. Одна бизнес-фраза может быть новым поведением системы

Хороший пример — порог 150 км. Бизнес сказал: если поезд дальше 150 км, просто мониторим. Если ближе — начинаем готовить приёмку. Звучит как простое условие. На деле это новый статус, другой режим интерфейса, ограничения на создание заявок, автоматические действия и вопросы к повторному изменению расстояния.

Рисунок 2. Когда к дислокации добавились накладные ЭТРАН, задача перестала быть просто мониторингом: появились клиенты, грузы, контейнеры, неоднозначные связи и правила сопоставления.

Рисунок 2. Когда к дислокации добавились накладные ЭТРАН, задача перестала быть просто мониторингом: появились клиенты, грузы, контейнеры, неоднозначные связи и правила сопоставления.

5. ЭТРАН принёс не только данные, но и грязь

Когда появились ЭТРАН-накладные, задача снова выглядела простой: связать накладную с вагоном и подтянуть груз, контейнеры, отправителя, получателя. Но реальные данные быстро охлаждают оптимизм.

ТЕХНИЧЕСКАЯ ВСТАВКА: ГРЯЗНЫЕ ДАННЫЕ

Дата 0001-01-01T00:00:00 — плейсхолдер ЭТРАН «дата неизвестна». PostgreSQL / TIMESTAMPTZ → OverflowError при сохранении. Решение: парсер проверяет год → если ≤ 1, пишет NULL.

Номер вагона в накладной может содержать: восемь нулей, латиницу, технические коды. Привязка строится в обратную сторону: активный рейс → валидный вагон → накладная (etran_waybill_wagons).

Рисунок 3. Финальная ценность прототипа была не в таблице, а в рабочем сценарии: оператор видит состав, выбирает вагоны, привязывает клиента и готовит данные для учётной системы.

Рисунок 3. Финальная ценность прототипа была не в таблице, а в рабочем сценарии: оператор видит состав, выбирает вагоны, привязывает клиента и готовит данные для учётной системы.


А теперь давайте честно

Где Claude ошибался

Важно упомянуть: Claude не был волшебной кнопкой. Он ошибался. Предлагал ORM там, где нам был нужен предсказуемый SQL. Добавлял красивые абстракции туда, где нужна была простая бизнес-логика. Недооценивал побочные эффекты синхронизации. Иногда уверенно предлагал решение, которое хорошо выглядит в вакууме, но плохо живёт на реальных данных. Поэтому рядом всегда были Git, ручная проверка, знание домена и готовность откатить неудачное направление.

ГЛАВНАЯ МЫСЛЬ

ИИ ускоряет черновую материализацию мысли. Но ответственность за архитектуру, качество и эксплуатацию остаётся на людях.


Что это дало аналитикам

Главный вывод не в том, что «аналитики теперь могут кодить». Главный вывод в том, что аналитик получает возможность раньше думать как системный проектировщик. Не просто записывать:

БЫЛО

Пользователь видит список вагонов и может оставить комментарий.

А разбирать:

→ Что такое вагон в этой системе? → Чем он отличается от рейса? → Какие события создают и завершают рейс? → Где источник истины? → Какие данные можно пересчитать, а какие нельзя терять? → Как система переживает грязные данные? → Какие ошибки требуют ручного разбора? → Какие вопросы ещё не решены бизнесом?

Это и есть зона, где рождается нормальное ТЗ. Не в красивом описании экрана, а в столкновении требований с моделью системы.

Что это дало разработчикам

Разработчики не должны угадывать систему по намёкам. После прототипа в разработку можно отдавать не туман, а более взрослую постановку:

  • Вагон и рейс — разные сущности

  • Поезд — группировка, но не стабильный ключ

  • Дислокация — поток событий

  • Комментарии нужно защищать от пересборки данных

  • ЭТРАН требует правил сопоставления и валидации

  • Синхронизация имеет побочные эффекты

  • Часть вопросов остаётся открытой и требует решения бизнеса

Это не снимает с разработки сложность. Production — это архитектура, тесты, безопасность, миграции, мониторинг, производительность, эксплуатация и поддержка. Прототип не должен быть аргументом «мы же быстро собрали, теперь и вы быстро сделайте». Его нормальная роль другая: убрать часть тумана до того, как он станет дорогим.

Как изменилось ТЗ после такой проверки

После прототипа ТЗ перестаёт быть пересказом первой встречи. В него попадает то, что обычно всплывает слишком поздно:

  • Глоссарий предметной области

  • Сущности и связи

  • Жизненный цикл рейса

  • Статусы и переходы

  • Правила создания, обновления, архивации и реактивации

  • Сценарии оператора

  • Исключения и ошибки

  • Правила работы с грязными данными

  • Интеграционные контракты

  • Ограничения на пересчёт

  • Требования к сохранению пользовательского ввода

  • Критерии приёмки

  • Список открытых вопросов

Такой документ всё ещё не идеален. Но это уже не «нарисуйте таблицу с вагонами». Это материал, с которым разработчик может работать без ощущения, что половину системы ему предлагают придумать самому.

Вывод

ИИ-инструменты часто обсуждают через скорость: быстрее написать код, быстрее собрать прототип, быстрее закрыть задачу. В нашем случае главное ускорение произошло не в коде. Оно произошло в понимании.

Мы быстрее увидели, что простое требование на самом деле скрывает рейсы, перецепки, поток событий, грязные данные, синхронизацию, накладные, комментарии и интеграции. И самое важное — мы увидели это до того, как отдали разработчикам финальную постановку.

Для аналитика ИИ может быть полезен не как способ заменить разработчика, а как способ раньше пройти путь от слов к системе.

Не вместо команды. Не для давления на сроки. А чтобы прийти к разработчикам не с туманом, а с нормальным инженерным материалом.

Хорошее ТЗ появляется не там, где один человек красиво написал документ. Хорошее ТЗ появляется там, где команда успела проверить понимание до того, как ошибка стала дорогой.


Эта статья выросла из внутренней работы над прототипом модуля «Дислокация» для ЛКДС. Над ней работали: Ведущий специалист Ильнур Садиков, Младший специалист Энгель Адылев и Старший специалист Айдан Казиханов.

Для нас этот кейс стал хорошим напоминанием: аналитика — это не только написать требования. Иногда это значит раньше всех пройти путь от простой бизнес-фразы до системы, в которой уже видны сущности, связи, исключения и будущие ошибки.