Интернет любит вечные войны. Linux против Windows. Vim против IDE. Tabs против spaces. Python против Java. Последняя особенно забавна: у каждой стороны есть священные аргументы, мемы и древние травмы.

Python-разработчики любят вспоминать: «В Java чтобы распечатать «Hello world» раньше нужно было написать диссертацию».

Java-разработчики отвечают: «Зато через три года мы всё ещё понимаем, что происходит».

Недавно прочитал пару больших материалов про производительность, RPS, экономику языков и выбор технологий для enterprise. В одном доказывалось, что современный Python уже достаточно быстрый. В другой пытались считать стоимость владения и стоимость разработки. Обе идеи разумные. Но после чтения осталось ощущение, будто кто-то пытается выбрать самолёт по одному параметру.

— этот летает со скоростью 900 км/ч.

А дальше вопросы:

— а он садится? А отказ двигателя переживает? А сертификаты? А кто его обслуживает?

— ...так, не усложняйте.

Почему RPS — это новый FPS

Есть очень популярная болезнь инженерных обсуждений: «5000 RPS на ядро!». Звучит впечатляюще. Но RPS без контекста — примерно как FPS в играх.

Потому что 5000 RPS может означать

return {"ok":true},

а может означать REST + PostgreSQL + очередь + интеграции + авторизация + бизнес-логика + аудит + кэш + внешние API. Разница иногда измеряется не процентами — а порядками.

В enterprise почти никогда не существует абстрактного «RPS». Есть p95, p99, время восстановления, количество команд, стоимость сопровождения, вероятность ошибок, требования аудита, требования сертификации. Один синтетический бенчмарк не отвечает ни на один из этих вопросов — он просто хорошо выглядит в слайде.

Сюрприз: большие Python-системы начинают походить на Java

Есть наблюдение, которое многие замечают, но редко произносят вслух. Маленький Python-проект — это:

  • app.py

  • views.py

  • utils.py

Python прекрасен, код читается как легко, все просто и понятно.

Через три года:

  • DTO

  • Services

  • Repositories

  • Factories

  • DI

  • Adapters

  • Layer1

  • Layer2

  • Layer3

и слоями поверх слоёв. И внезапно выясняется, что команда постепенно построила Java — только без компилятора, который на тебя кричит.

Тут обычно начинается следующая стадия. Кто-то написал давно:

process(data).

Через два года:

— а что такое data?

— никто не знает.

— а почему там иногда строка?

— исторически.

— а почему иногда список?

— исторически.

— а почему иногда None?

— ....

С этого момента шутки про Java начинают казаться менее смешными.

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

Почему техлиды постепенно начинают любить скучные вещи

В начале карьеры кажется: меньше кода — лучше. Потом появляется команда 20–50 человек. Потом сотни тысяч строк. Потом дежурства. Потом звонок в 3 ночи с вопросом «почему упал прод».

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

В этот момент начинаешь понимать странное поведение Java-разработчиков. Они не любят типизацию. Они любят спать.

Небольшая история про AWOS

Недавно мне пришлось выбирать язык для вполне реального проекта — системы автоматической аэропортовой метеостанции AWOS (Automated Weather Observing System).

Требования там были уже совсем не из мира обычного корпоративного CRUD: сбор данных с погодных сенсоров, вычисления по алгоритмам FAA, формирование голосовых сообщений, передача по радио и на автоответчик телефонной линии, поддержка дополнительных сообщений. Например, Bird activity in the vicinity of the airport. Раньше этим занимался человек с микрофоном. Потом появились системы со словарями записанных фраз. Теперь планируется синтез речи.

Но главный нюанс был в отказоустойчивости. Даже если основной софт упал, голосовое сообщение должно продолжать работать. Просто вместо обычной погоды станция обязана говорить: weather observation not available. Это требование FAA, а не пожелание заказчика — голосовой канал для пилотов должен работать всегда.

И тут внезапно появляются слова: детерминизм, предсказуемость, сертификация, отказоустойчивость. То есть начинается уже вполне настоящий enterprise.

Почему существующие решения выглядят как археология

Существующие AWOS-системы в большинстве своем выглядят как путешествие в прошлое: специализированные контроллеры двадцатилетней давности, стоят как крыло от самолёта, но при этом умеют меньше дешёвого мини-компьютера сегодня. Зачастую TCP — отдельная опция. Шифрование? Ну вы многого хотите. Отправить что-то в JSON-е куда-то по API — забудьте.

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

Кандидаты

Python рассматривался серьёзно. Проблема появилась на слабом железе — промышленные SBC (одноплатные компьютеры) Advantech и им подобные — это не игровой ПК разработчика. При росте числа сенсоров и скорости потока данных загрузка CPU становилась заметной. Но главная проблема оказалась неприятнее: Garbage Collector. На обычной машине редкие паузы GC можно даже не заметить. Но если у тебя в этот момент крутится голосовое сообщение для аэропорта — внезапные остановки начинают нервировать. Фраза wind two seven... [тишина] ...gusting three five может вызвать у пилотов интересные эмоции.

C — очень быстр, и GC-пауз нет по определению. Но количество кода и кроссплатформенный сетап быстро вырастают в проблему. Когда начинаешь писать третий слой оберток вокруг системных вызовов, то быстро хочется бросить проект.

Node — скриптовый язык со всеми вытекающими (производительность, GC, типизация - так себе, экосистема ориентирована на веб. Но, к счастью, мы не ограничены браузером, выбор есть.

TypeScript — логичный вопрос: зачем? TypeScript добавляет типизацию поверх JS, вроде все. Все остальные недостатки Node остаются.

Go — был серьёзным кандидатом, его каналы и корутины это как раз то, что нужно для работы с сенсорами. Но в итоге показалось, что слишком сложно настроить кросс-платформенную среду разработки, особенно для работы с COM-портами. Внезапно появились глючные C-библиотеки, нетривиальность сборки для разных вариантов железа, зависимости и прочий кроссплатформенный зоопарк, на который можно потратить дни. Преимущество простоты деплоя испарилось.

С# — для Windows наверное он бы победил, но в плане кросс-платформенной совместимости и разработки он пока недостаточно зрелый.

Почему в итоге Java

Победила Java. Не потому что «Java самая быстрая во вселенной», а потому что одновременно сошлись нужные требования.

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

Производительность на слабом железе — промышленные SBC от Advantech — не датацентр, но даже на нем JVM с современными GC справляется достаточно предсказуемо.

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

Бинарная переносимость — один артефакт, разные CPU, разные ОС, меньше боли при обновлениях на парке устройств.

Современный GC — многие до сих пор обсуждают Java так, будто на дворе 2008. ZGC и Shenandoah дают паузы в единицы миллисекунд даже на больших хипах. Для голосового вывода даже на слабеньком двухъядерном Arm этого достаточно. Старые мемы больше не актуальны.

Зрелая экосистема для промышленных задач — библиотеки для работы с сетевыми протоколами и аппаратным интерфейсом давно обкатаны десятилетиями в production.

Резюме

Я не призываю переходить на Java религиозно. И не утверждаю «Python плохой». Python дейсвительно прекрасен — особенно для автоматизации, data, ML, быстрых сервисов, прототипов. Огромный класс задач решается на Python лучше, быстрее и дешевле.

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

Комментарии (31)


  1. Dhwtj
    23.05.2026 04:50

    Скорость, сопровождаемость (через явность и типизацию), надёжность, отсутствие GC

    Я всё ждал, когда же вы до Rust дойдете


    1. Wosk1947
      23.05.2026 04:50

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


      1. amaksr Автор
        23.05.2026 04:50

        Для энтерпрайза Раст это все-таки пока экзотика. Где-нибудь в стартапе - наверное да. Но я Раст пока видел только у студентов.


        1. Dhwtj
          23.05.2026 04:50

          Видимо, студентам придется подрасти прежде чем Rust вместе с ними придёт в энтерпрайз.


  1. panzerfaust
    23.05.2026 04:50

    В Java чтобы распечатать «Hello world» раньше нужно было написать диссертацию

    Иронично, что необходимость написать АЖ ЦЕЛЫЙ ОДИН КЛАСС стала непреодолимым барьером для миллионов.


    1. tuxi
      23.05.2026 04:50

      там наверное spring поднимали как минимум )))


  1. svpcom
    23.05.2026 04:50

    Интересно, а что нужно сделать, что бы метеостанция тормозила на питоне из-за GC? Похоже что мы что-то делали не так в скайпе (до того, как его сгноил MS), что у нас backend на миллионах пользователей не тормозил… Просто не используйте потоки, а делайте асинхронный код (привет twisted) и включайте голову. Но нет, мы притащим жабу на одноплатник…

    P.S. Специально для любителей функций со скоростью роста n^n


    1. amaksr Автор
      23.05.2026 04:50

      На одном студенческом проекте на circuitpython (кастомный USB джойстик-кейпад для компа) на слабом железе, наблюдал интересный феномен: в обычном режиме все вроде работало нормально, кнопки опрашивались, нажатия отправлялись, каждую секунду печаталось количество свободной памяти в пределах нормы, все в общем ок. Но когда из компьютера приходил файл конфигурации, который надо было распарсить средствами питона (а это куча операций по разбиению строк на новые строки, которые в питоне все на куче), то потом начинались незатухающие осцилляции количества свободной памяти с периодом в несколько секунд и с рандомным шансом упасть, плюс все сопровождалось замираниями, т.к. circuitpython останавливает все на время работы GC. На нормальных компах это никто не смотрит, но на слабых оказалось проблема. Метеостанция таким парсингом занята постоянно, поэтому просто отмахнуться бы не получилось.


      1. svpcom
        23.05.2026 04:50

        Как уже правильно было отмечено ниже, в питоне используется счетчик ссылок за O(1), а GC работает только если есть циклические зависимости. Так что можно переписать парсер так, чтобы он не городил объекты с циклическими ссылками и выключить автоматический GC (gc.disable()) и вызывать руками gc по таймеру (или не вызывать вообще, если вы все циклы в ссылках удалили). Мы так делали и при должной осмотрительности все работает отлично. Если есть какой-то тяжелый входной формат, то можно сделать offload через cython иди просто написать тяжелый кусок на C/C++ в виде библиотеки и через cffi подключить.


    1. pkokoshnikov
      23.05.2026 04:50

      Асинхронный код это дополнительная сложность, порог входа и всё остальное. Зачем её нести в проект если можно писать проще?


      1. svpcom
        23.05.2026 04:50

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


    1. Tishka17
      23.05.2026 04:50

      Особенно с учётом, что в питоне используется счётчик ссылок, а gc только для поиска циклов и в целом можно отключить. А вот в джаве Гц для всего


  1. tuxi
    23.05.2026 04:50

    Python прекрасен, код читается как легко, все просто и понятно.

    Что простите? Вот эти все отступы табуляторами - это легко и понятно? Имхо, это только для тех, у кого Пайтон был первым языком


    1. svpcom
      23.05.2026 04:50

      Он отлично читается в отличии от rust, который взял самые худшие черты ruby, c++ и perl


    1. Andrey_Solomatin
      23.05.2026 04:50

      А вы джаву одной строкой пишете? Или по той же логике, что и в Питон форматирует код?


      1. tuxi
        23.05.2026 04:50

        у меня code style 2 пробела отступ, а таб - это 7 пробелов. Поэтому когда я открываю код на пайтоне - у меня кровь из глаз.
        А вообще, я зарекся упоминать пайтон, в этот раз опять особо нервные в карму залезли. Ведь иного, кроме их мнения, быть не должно.


        1. Andrey_Solomatin
          23.05.2026 04:50

          Два для Питона маловато, особенно если много длинного кода. Для остальных языков тоже не очень добавляет читабельности, но в некоторых так сложилось. А вот таб на 7 это необычно, расскажите подробнее.

          У меня на табе 4 и я пробела и я руками никогда пробелы не ставлю.

          Вы один или в команде работаете?


          1. tuxi
            23.05.2026 04:50

            Я немного ошибся, в табе не 7 пробелов, а 8 по стандарту. Я с пайтоном не работаю, но иногда приходится открывать сорцы на нем.

            Вы один или в команде работаете?

            Есть проекты где в команде, есть проекты где я один.
            2 пробела - для меня удобно, если в каком-то проекте 4 пробела - то вполне можно и с таким жить.


            1. Andrey_Solomatin
              23.05.2026 04:50

              8 это норм, только вот зачем иметь 2 и 8 в одном и том-же коде?

              Хотя на джаве там вообще ни таб ни пробел нажимать не надо, просто там редактор ставит курсор на нужное место по переходу на следующую строку. В питоне иногда нужно, для переписывания существующего кода, но там я как раз таб жму, чтобы добавить / удалить нужное количество пробелов.


              1. tuxi
                23.05.2026 04:50

                Ну вот когда в notepad-е открываешь питоновский код, чтобы быстро глянуть, что там за косяк и хочется ругаться матом..


  1. Alex-Freeman
    23.05.2026 04:50

    Странно что Kotlin не рассматривали.


    1. pkokoshnikov
      23.05.2026 04:50

      А зачем? Есть какие-то серьёзные приемущества по сравнению с java?


      1. KoIIIeY
        23.05.2026 04:50

        Есть, проверка на нулл, да и прочий красивый удобный сахар


        1. Antoshink
          23.05.2026 04:50

          Превращающий этот язык в сахарный мусор


  1. titan_pc
    23.05.2026 04:50

    Ну да. Весь мир embedded device. Просто так видимо на чистом С едет. Там где даже ОС нет.

    Для тех у кого код превращается в макароны - чистую архитектуру придумали. Линтеры, код стайлеры и всякие разные вот эти вот "лишние" истории.

    Для тех кто чужой код двухлетней давности читать не умеют - курсор с ИИ разработали.

    Сказать что Java с её jvm как то сэкономит ресурсы по отношению к другим звучит весело.

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

    Я бы С взял. В нём всё понятно и через 100 лет будет.


    1. SemiHDD
      23.05.2026 04:50

      Мне кажется лучше на java, тк в мире энтерпрайсов больше всего джавистов чем остальных в процентном соотношении


      1. Andrey_Solomatin
        23.05.2026 04:50

        Проект в статье не энетерпрайз. Это достаточно изолированный проект, который может написать один человек.


    1. Andrey_Solomatin
      23.05.2026 04:50

      Я бы С взял. В нём всё понятно и через 100 лет будет.

      Так вы курс по джаве не продадите.


  1. Antoshink
    23.05.2026 04:50

    Вы не много не туда пошли. Java все таки не для таких задач создан. Тут идеальный выбор C или C++. Все остальное натягивание своего мировоззрения.


  1. Andrey_Solomatin
    23.05.2026 04:50

    С# — для Windows наверное он бы победил, но в плане кросс-платформенной совместимости и разработки он пока недостаточно зрелый.

    А мужики то и не знают.


  1. kain64b
    23.05.2026 04:50

    С# — для Windows наверное он бы победил, но в плане кросс-платформенной совместимости и разработки он пока недостаточно зрелый.

    Это в каком году статья писалась? Вроде +- java в этом плане выровнялись давно.