Pull to refresh

Проверяем Архитектурные стили на движке Factorio (часть 2, SOA)

Reading time27 min
Views27K

Для понимания того, чем мы тут занимаемся обязательно прочтите предыдущую статью:

Часть 1

Вводная

Добрый день снова, дорогие читатели!

В продолжение первой части мы сегодня будем снова пробовать разные Архитектурные стили и сегодня мы переместимся с Монолита на Сервисо-ориентированную архитектуру (Service-Oriented Architecture или SOA) на движке Factorio. Наконец-то мы не просто соберём данные, но ещё сравним их с нашим предыдущим замером различных параметров - с Monolith.

Наконец-то мы узнаем, какие преимущества имеет первый и второй стиль. А то ли ещё будет позже!

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

Начнём!

Сервисо-ориентированная архитектура (Service-Oriented Architecture или SOA)

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

Именно в нём начались первые попытки разбивать запутанные, монолитные приложения по программной логике: что-то занимается фронтом, что-то считает деньги, что-то хранит файлы, что-то взаимодействует с БД и так далее. Чтобы всё это работало относительно независимо друг другу, придумали всё соединять некой шиной - Enterprise Service Bus (далее просто "Шина"). Именно эта шина содержала в себе логику "что, куда и при каких условиях отправлять", а при этом остальные сервисы просто принимают от шины запросы, обрабатывают их и возвращают обратно в шину.

На бумаге это выглядит так, что каждый сервис можно назначить определённую команду программистов и они будут писать код под стандарты Шины не отвлекаясь на то, то твориться в соседних командах/сервисах.

Однако, если углубится в Интернет за поиском дополнительной информации по этой архитектуре, то можно увидеть по ней есть прямо множество статей, но при этом все этот стиль не рекомендуют к применению. А причина проста - она содержала кучу критически важных минусов для Продукта. При этом популярность её обусловлено тем, что именно она дала толчок для развития в сторону других Архитектурных стилей (Service-Based, Space-Based, Event-Driven и Microservices), которые мы ещё рассмотрим в будущем.

У SOA выделяют один существенный недостаток - запутанная логика в Шине. То есть когда приложение будет расширяться, всё больше и больше логики "что-куда-когда" будет заноситься в Шину, а поскольку она является критическим, связующим звеном для всех сервисов - ошибка в ней чревата сбоями в работе приложении. Плюс к командам разработки отдельных сервисов ещё появляется необходимость выделения и команды разработки Шины, работа где будет сложна: поддержка критичной для приложения компонента; постепенно растущая и запутывающаяся логика работы Шины; множество взаимодействий с командами Сервисов со своими уникальными хотелками. В общем, именно на этом аспекте и не удалось получить от Архитектурного стиля ни ускорения разработки, ни надёжности.

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

Предварительный план

Давайте сразу же определим основные аспекты Стиля и попробуем перевести это в игру до её начала.

Во-первых, REST API к этому моменту ещё не так был популярен для использования, а значит различные производства будут связываться через всё те же конвейера. Разница только в том, что теперь нам нужно подводить сырьё к заводу по Шине и в неё же вливать результат производства.

Во-вторых, пользователи всё так же будут приходить к нам в приложения по ЖД. И как и в Monolith'е, в SOA это должно быть единственное использование ЖД во всём продукте.

В-третьих, ни в коем случае нельзя смешивать производства, как это было в Monolith'е - если уж ответвились для создания, например, Зелёных Микросхем, то только для Зелёных Микросхем эта ветка и предназначена.

В-четвёртых, электростанция тоже будет частью одной из веток Шины. Но она будет только потреблять ресурсы с Шины, а не отдавать (электричество особо на конвейер не положишь).

В-пятых, трубы с жидкостями так же придётся вести по Шине.

В-шестых, конвейера в Шине должны будут двигаться в обе стороны т.к. ряд сырья будет требоваться не только впереди по заводу, но и сзади (например, то же ядерное топливо из середины Шины придётся вести к электростанции, располагаемой в самом начале).

В целом всё. На данный момент я вижу тут две сложности и одну легкость:

  • Первая сложность - я не представляю, как будет работать Шина и насколько сложно/возможно будет её обслуживать;

  • Вторая сложность - из-за всё той же Шины весь завод будет занимать кучу места, на что достаточно скоро сагрятся жуки;

  • Легкость - вертикально расти при такой схеме будет значительно проще. Главное оставлять пространство между ответвлениями от Шины.

Пока же я набросал следующую схему Шины:

В теории всё выглядит хорошо: заводы будут расширятся условно бесконечно вниз, а Шина расширяется условно бесконечно вправо и, чуть медленней, вверх. Даже есть место чтобы развернуть некоторые конвейера в случае необходимости (наверное).

Но опять же - это всё прототип, а игра не так проста и в ней явно возникнут сложности ближе ко второй половине игры. По сути тут нужно будет всегда соблюдать правило "не тулить" и оставлять место как между ветками, так и в самой Шине. Ну и нужно будет ОЧЕНЬ много конвейеров и труб...

В общем, думаю, что можно пробовать начинать...

Старт игры. Пилот

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

Ну и для науки: видимо отныне все Архитектурные стили всегда придётся начинать с мини-Monolith'а. Это даже чем-то напоминает на MVP.

В целом мой план работает хорошо: сначала я подключил переплавку ресурсов, потом перенёс электростанцию в начало, ну и продолжил создавать различные зоны производства (шестерёнки, колбы и т.д.). Пока всё это хорошо расширяется - заводы можно расширять вниз, а Шину - вправо. А если будет достигнут лимит по расширению завода - никаких проблем не будет сделать ещё одну зону с аналогичным производством далее по Шине.

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

Чуть позже у меня нарисовались две проблемы:

Во-первых, у меня меня достаточно быстро истощились стартовые рудник железа, меди и камня, а до ЖД было ещё далеко (я даже не успел наладить производство Зелёных микросхем для Зелёных колб). В итоге пришлось временно тащить пару путей из конвейеров от ближайшей жилы. Когда у меня будет ЖД - я переведу этот костыль на поезда, но пока только так. Относительно Продукта это означает что мы начали не укладываться в Сроки - вместо того, чтобы полноценно впустить пользователей мы всё ещё работаем с ограниченным числом пользователей. То есть у нас происходит что-то вроде закрытого Альфа-тестирования, но при этом приложение готово взять и бóльшую нагрузку - странная ситуация.

Во-вторых, я территориально разросся так, что уже начал подходить к месту дислокации Жуков. То есть мы ещё в добавок начали выходить за Бюджет. Поскольку скоро начнутся нападения (ака нападки Бизнеса на неукладывание в бюджет), я прервал наладку производства Зеленых колб и сконцентрировался на производстве оборонительных сооружений (стены, турели и патроны к ним) и Чёрных колб. На текущем этапе игры убивать их ульи крайне сложно - у меня открыто не так много исследований на военное дело, а воюю уже со Средними червями. В общем, когда "Бизнес" начинает давить на проект в плане затрат - начинается крайне нервная работа в пустую по обоснованию Сроков и Бюджета. Позже, с увеличенным уроном и гранатами, уничтожать ульи стало легче, но всё это всё равно на это потратился достаточно ощутимый процент общего времени, которое можно было бы потратить на движение по пути полноценного старта работы пользователей.

В общем, всё плохо.

Зато я, как ни странно, я не испытываю проблем с Конвейерами: как только я наладил производство Желтых Конвейеров оказалось, что их производственных мощностей хватает для поддержки как Шины, так и Завода в целом (если помните, в Monolith'е с этим были большие проблемы). В общем, как ни крути, Архитектура медленно и верно начинает себя окупать.

Сама Шина уже начинает разрастаться так, что её становится проблемно обслуживать - даже её план уже в экран не помещается. Пришлось снова чуть-чуть отвлечься от ЖД и сделать производство радаров - расставив их, смог удобней работать с картой и с разросшейся Шиной стало проще.

Ещё очень много тратится времени на расположение, строительство и подключение Шины. При этом полностью воспользоваться вместимостью этой Шины так и не смог - по её широким каналам перемещаются тонкие ручьи предметов и только в где-то в конце оно накапливается в ожидании потребления...

Ну а спустя некоторое время я вообще упёрся в большое озеро по пути хода Шины и пришлось ещё раз отвлекаться на производство земли для отсыпки территории.

В общем, одни проблемы и я не представляю, как это всё можно было бы предугадать на первоначальном этапе планирования работы с SOA. Уже прошли игровые сутки, а я даже не успел поставить производство предметов для запуска ЖД (напомню, что в Monolith'е к суткам игры мы уже завершили игру).

Из хорошего могу отметить следующее:

  • Расширять Шину и подключать к ней заводы оказалось достаточно просто, хоть и долго - по сути работает принцип копировать-вставить и дальше начинают работать дроны. Короче, достаточно монотонная работа;

  • Затыков на Шине нет - все ресурсы поступают вполне себе равномерно и есть ещё много места для роста;

  • Шину не обязательно прямо всегда строить, тратя конвейеры - редко используемые потоки ресурсов можно не вести вперёд до востребования, однако нужно не забывать всегда оставлять под них места в Шине.

И ещё отмечу один минус: всё это очень трудозатратно по предметам, по территории и по времени - бюджет на разработку явно раздуется на всё это безобразие, а начало получения прибыли всё откладывается и откладывается...

Обрастание фичами

ЖД наконец-то подключено - железо, медь и уголь полились рекой.

Уже сейчас можно заметить, что всё развитие продукта движется крайне медленно: если в Monolith'е основной проблемой было придумать как втулить то или иное запутанное производство, то здесь таких вопросов не возникает, но от этого времени и ресурсов уходит далеко не меньше.

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

Ещё я заметил, что ресурсов как таковых у меня много, но вот они все застряли в неактуальных местах: то в самой Шине, то на не приоритетном производстве - в Monolith'е подобного у нас такого не наблюдалось в подобных масштабах. Зато если построить завод в текущем конце Шины, то все эти зависшие ресурсы из Шины идут именно на новое производство и мы на первое время получаем заметный прирост данный предметов. Из-за этого на графиках всегда можно заметить пик производства в самом начале, а потом оно нормализуется.

Ещё странным выглядит подключение к Шине тех производств, которые не могут быть продолжены (например, Электрические столбы, Длинные манипуляторы, Ящики). У меня возникало куча вопросов вида "зачем они здесь, ведь оно не будет давать результата обратно в Шину"? Но правило есть правило.

Жуки прямо покоя не дают: вдалеке от центра их много и они хорошо защищены. И неизвестно, что с этим можно сделать: в Monolith'е удавалось с ними мало контактировать из-за малого размера завода; в будущих Microservices'ах я предполагаю, что можно будет делать производства равномерно от центра. Но в SOA мы просто ведём Шину в одну сторону навстречу ульям на весь экран и Чудовищным червям.

Забавный случай произошёл с Шиной: когда я реализовал производство Синих колб я понял, что мне нужно будет везти их обратно в начало шины, где у меня располагаются Лаборатории. Но это оказалось не так просто т.к., во-первых, придётся вести достаточно дорогостоящие Синие колбы через весь завод, что крайне накладно; во-вторых, места для "обратного" хода конвейера внезапно не нашлось и пришлось вести их по достаточно запутанному пути, чтобы обойти все уже существующие дорожки Шины. В итоге нашлось неожиданное решение перенести Лаборатории в центр Шины, что решило эти две вышеуказанных проблемы, но добавило кучу работы по переделке Шины

Такие же проблемы были и с патронами, и ракетным топливом для поездов, и с ядерным топливом для электростанций. В общем, Шина начинает усложняться и явно не этого хотели от SOA архитекторы в своё время.

В целом по карте загрязнений можно увидеть, что активно работает только заводы в начале и конце Шины:

Объясняется это просто: в начале производства находится электростанция и переплавка руд, поэтому они "фонят" всегда и сильно. В конце находятся недавно запущенные заводы, которые ещё не успели заполнить Шину своей продукцией. Ну а в центре (преимущественно) находятся уже те заводы, которые успели отработать и остановится из-за того, что "Выход заполнен".

Есть и хорошие новости:

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

Во-вторых, сделать дублирующее производство, если чего-то не хватает, проще простого - скопировал и подключил к Шине. Например, я так делал с шестерёнками и зелеными/красными микросхемами и получил заметный прирост их производства. Главное - это вовремя сообразить, что у тебя есть нехватка чего-бы то ни было.

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

Интересности были с электричеством:

Сначала оно кончилось просто потому-что стало поступать мало воды - пришлось переносить его со старого места ближе к озеру (по сути подключать воду в обход Шины). Позже истощилась шахта с углём начались нарушения поставки угля к бойлерам - пришлось отвлекаться и аварийно создавать ещё пару удалённых шахт угля. Ну и аккурат к переходу на АЭС я понял, что достиг максимума в использовании паровых двигателей. Конечно, можно было бы ещё попробовать как-то оптимизировать подачу пара, но благо этого не потребовалось.

Атомка без проблем запустилась не смотря на достаточный долгий процесс обогащения урана - Шина позволила принять много урана и достаточно быстро обеспечить подачу урановых стержней на Шину. Если помните, на Monolith'е я АЭС сделал чуть ли не в конце игры т.к. процесс обогащения урана еле-еле "разгонялся".

Ну и последнее - по исследованиям:

Колб как таковых всегда хватает - делаешь производство и их всегда поступает тысячами в Шину. Но сделать производство новых видов колб реально занимает много времени. В итоге получается такая картина: быстро открываются все исследования, которые требуют тех колб, производство которых у меня уже налажена, но потом возникает долгая пауза в исследованиях т.к. для них нужны новые виды колб; потом производство новых видов колб всё же запускается и вся очередь исследования достаточно шустро открывается; потом опять начинается потребность в новых видах колб и начинается долгая пауза... Чую, что итоговый график будет похож на лесенку - посмотрим по завершению текущей игры. Напомню, что в Monolith'е была ситуация более сбалансированной: пока изучаешь текущее исследование - активно строишь заводы на новые виды колб (хотя и под конец игры этот принцип стал сбоить).

В общем, если вы используйте SOA, готовьтесь к тому, что вы будете долго-долго оставлять Бизнес без актуальных фич просто потому-что морочетесь с Архитектурой как таковой, но потом сможете выкатить всё пачкой и с достаточно большим запасом по производительности.

Рывок до конечной цели

Пришла пора начинать создание ракеты. Тут можно выделить три интересности:

Во-первых, хоть я и расширял создание Зеленых микросхем - их всё равно катастрофически мало. А всё потому-что их производство находится очень далеко от актуального производства и большая часть продукции "сжирается" по пути. И тут не помогает ни переход на Красные конвейера, ни переход на улучшенные виды заводов, ни масштабирование. В общем, индивидуальный контроль внутри Шины требует дополнительных трудовложений и ещё больше увеличивает сложность Продукта.

Во-вторых, под конец я столкнулся с похожей мыслью, что была и в начале - "Зачем мне выводить в Шину дорогостоящее производство, если можно подключить её в рядом стоящую ракетную шахту". Посмотрите сами на то, как близко располагается производство Спутников от Ракетной шахты и думаю, что у вас тоже возникнет желание не тянуть их в Шину, а подключить напрямую. Но правило есть правило.

И на этот раз это реально не окупилось - ну зачем мне полная линия дорогостоящих спутников, если достаточно одного раз в несколько часов?

В третьих, из-за перепроизводства стали кончаться уже существующие шахты/жилы нефти, меди и железа. Это странно т.к. я их достаточно много наделал когда подключал ЖД. Но, видимо, это такая особенность Архитектуры - так сказать "Цена за самоподдержание".

Итого по финалу:

  • Затрачено реального времени в 23 дня;

  • Убито жуков: 2'411'763

  • Убито червей: 3848

  • Убито ульев: 3626

Вот ещё я сделал гифку сравнения размера завода с Monolith'ом:

Сохранение

Видео

Во всей этой картине меня особенно пугает не затраченное время, не количество убитых кусак, а на почти 2.4к убитых Чудовищных червей. Не думаю, что другие архитектуры покажут такие же цифры.

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

Мне этом приложение напоминает старые, исполняемые файлы на Java: один большой, исполняемый файл, который просто, но долго переносить, а так же запускается он крайне медленно.

Сразу же после окончания у меня встал вопрос: "А сколько же я времени убил на развитие Шины по сравнению с остальными работами?". По ощущениям это было около 40%. Чтобы проверить это я поделил реплей на 11 частей и замерил, сколько времени я тратил на работу с Шиной. Вот результат:

В целом ощущения не подвели - 30-40% времени в зависимости от этапа. При этом можно заметить, что график достаточно равномерный и по мере развития приложения баланс количества работы над Шиной к работе над самим Приложением более-менее сохраняется.

Теперь переходим к замеру параметров данного Архитектурного стиля.

Evolvability

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

В отличие от Monolith'а, в текущем Архитектурном стиле пришлось изучать ещё много чего дополнительно, чтобы справится с Жуками и построить завод на озере. Плюс был немного изменён порядок исследований - то есть у нас появился такой фактор как "Сервисные фичи". Это означает, что есть не представляющие особой ценности Бизнесу, но необходимы для того, чтобы Архитектура работала как таковая.

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

Исследование

Время для Monolith

Время для SOA

Автоматизация

00:54:35

00:31:31

Логистический исследовательский пакет

01:01:53

00:43:24

Производство стали

01:04:37

00:37:34

Логистика

01:07:14

00:30:36

Пулемётная турель

01:08:41

00:44:20

Электроника

01:12:27

00:35:22

Логистика 2

01:29:01

10:58:13

Двигатель

01:38:41

10:55:09

Железные дороги

01:46:36

10:59:24

Автоматизация железных дорог

01:54:05

11:00:32

Железнодорожные сигналы

02:04:03

11:02:00

Военная промышленность

02:04:26

01:04:27

Каменная стена

02:04:45

00:49:07

Военная промышленность 2

02:05:47

11:11:00

Военный исследовательский пакет

02:08:42

11:11:19

Продвинутая металлургия

02:16:33

11:09:18

Огнестрельный урон

02:22:54

01:54:49

Скорострельность оружия

02:27:14

01:29:43

Огнестрельный урон 2

02:35:39

11:04:50

Скорострельность оружия 2

02:44:53

11:07:44

Огнестрельный урон 3

03:21:40

19:36:24

Быстрый манипулятор

03:22:17

00:48:12

Автоматизация 2

03:22:53

11:08:08

Транспортировка и хранение жидкостей

03:23:41

11:11:51

Вагон-цистерна

03:30:01

11:14:46

Переработка нефти

03:33:41

11:19:48

Скорость лабораторий

03:38:00

11:16:14

Скорость лабораторий 2

03:48:23

11:18:45

Электроснабжение 1

03:55:13

11:40:48

Обработка серы

04:08:43

11:21:28

Взрывчатые вещества

04:11:04

11:31:50

Аккумулятор

04:18:41

11:28:04

Пластмассы

04:31:33

11:23:49

Продвинутая электроника

04:52:07

11:25:44

Химические исследовательская пакет

04:57:29

11:26:22

Пояс для инструментов

05:04:18

11:10:48

Пакетный манипулятор

05:18:05

11:34:05

Бонус вместимости манипулятора 1

05:29:31

11:44:52

Бонус вместимости манипулятора 2

05:51:40

11:47:31

Модули

06:05:41

11:29:09

Модуль скорости

06:13:55

11:29:46

Модуль продуктивности

06:21:32

11:30:23

Стационарный аккумуляторы

06:43:18

11:42:43

Продуктивность добычи 1

07:26:42

11:39:28

Огнестрельный урон 4

07:43:50

20:38:24

Ворота

07:45:57

11:53:37

Оптика

07:46:10

01:03:08

Солнечная энергия

07:53:07

11:50:58

Скорострельность оружия 2

08:07:46

11:36:23

Горючие жидкости

09:11:45

11:34:40

Дрон-защитник

09:24:49

21:53:30

Количество следующих за персонажем дронов 1

09:58:13

22:07:49

Количество следующих за персонажем дронов 2

10:48:08

22:15:10

Бетон

10:52:31

12:01:41

Продвинутая переработка нефти

10:53:51

73:35:46

Смазочная жидкость

10:54:50

74:23:11

Продуктивность добычи 2

11:21:01

74:47:59

Переработка урана

11:33:58

74:31:40

Продвинутая металлургия 2

11:50:32

74:36:51

Ядерная энергия

12:37:14

74:39:04

Производственный исследовательский пакет

12:42:13

74:37:48

Конструкция малой плотности

13:02:14

74:41:09

Ракетное топливо

13:22:09

74:52:16

Процесс обогащения им. Коварекса

15:29:05

85:48:59

Переработка ядерного топлива

15:33:37

86:21:06

Электродвигатель

15:34:31

74:23:42

Робототехника

15:35:50

74:24:22

Скорость рабочего дрона 1

15:36:51

74:27:12

Сила торможения 2

15:37:14

74:14:54

Скорость рабочего дрона 2

15:38:35

74:28:08

Сила торможения 1

15:40:28

74:12:34

Продвинутая электроника 2

16:06:20

74:34:20

Вспомогательный исследовательский пакет

16:13:01

74:48:57

Скорость лабораторий 3

16:29:44

74:17:51

Скорострельность оружия 5

17:03:17

74:17:52

Сила торможения 3

17:19:43

85:55:42

Сила торможения 4

17:43:03

86:15:55

Сила торможения 5

18:13:07

86:20:34

Блок управления ракетой

19:15:06

115:23:24

Модуль скорости 2

19:16:09

74:59:50

Модуль продуктивности 2

19:17:12

75:00:35

Модуль продуктивности 3

19:25:36

86:47:16

Модуль скорости 3

19:34:08

86:43:26

Ракетная шахта

20:34:18

115:30:55

Космический исследовательский пакет

23:24:52

115:30:01

Автотранспорт

11:54:54

Скорость лабораторий 4

74:22:41

Скорость лабораторий 5

86:01:48

Взрывчатка скал

11:52:28

Портативная солнечная панель

11:57:55

Автоматизация 3

86:04:33

Атомная бомба

116:08:47

Бонус вместимости манипулятора 3

75:02:50

Бонус вместимости манипулятора 4

86:11:14

Бонус вместимости манипулятора 5

86:28:21

Бонус вместимости манипулятора 6

86:32:29

Бонус вместимости манипулятора 7

116:11:33

Лазерные технологии

75:29:25

Личный аккумулятор

11:59:00

Логистическая робототехника

74:26:38

Логистическая сеть

11:48:15

Модуль эффективности

11:30:57

Модуль эффективности 2

75:01:20

Модульная броня

11:57:14

Мины

21:48:32

Прибор ночного видения

11:58:17

Портативный генератор электрического щита

21:57:51

Огнемет

20:46:38

Ракетостроение

21:55:27

Оборудование для игнорирования конвейеров

11:58:39

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

11:32:27

Скорострельность оружия 3

21:27:26

Скорострельность оружия 4

21:45:26

Переработанное горючие 1

21:50:59

Переработанное горючие 2

22:02:52

Стальной инструмент

01:01:45

Танк

03:32:07

Тяжелая броня

02:02:24

Усиленная взрывчатка

11:56:02

Усиленная взрывчатка 2

19:08:11

Военная промышленность 2

73:32:50

Взрывные боеголовки

73:34:28

Усиленная взрывчатка 3

73:46:13

Огнестрельный урон 5

73:59:08

Скорострельность оружия 5

74:11:14

Грузоподъёмность рабочего дрона 1

74:29:56

Военная промышленность 3

115:24:17

Огнестрельный урон 6

116:15:29

Скорострельность оружия 6

116:19:24

Усиленная взрывчатка 4

116:22:02

Скорость рабочего дрона 2

116:23:00

Усиленная взрывчатка 5

116:26:28

Усиленная взрывчатка 6

116:30:22

Скорость лабораторий 6

116:32:32

Сила торможения 6

116:35:06

Сила торможения 7

116:38:54

Продуктивность добычи 3

116:44:30

Скорость рабочего дрона 4

116:45:53

Скорость рабочего дрона 5

116:48:50

Диаграмму придётся обезличить т.к. порядок исследований был нарушен. Вот график "по возрастанию" количества исследований:

Шкала оси Y - сутки; шкала оси X - исследование по порядку.

Что можно сказать по этому графику:

Самое главное и очевидное с первых часов игры - на достижении всех основных целей потребовалось в 5 раз больше времени, чем в Monolith'е. То есть, чтобы примерно сравняться по времени разработки с Monolith'ом нужно увеличивать команду разработки в 5 раз.

Я знаю правило по поводу увеличения количество сотрудников в проекте вида "две женщины не могут родить в 2 раза быстрее", но тут я это намеренно опустил из расчётов т.к. другой коэффициент продуктивности по увеличению количества программистов я удачно применить не могу. В разных компаниях эта формула разная: можно нанять наивысших специалистов с ЗП по 1 кв.метру квартиры в Сингапуре в месяц, но которые будут работать 24/7 и выдавать ту самую удвоенную (а то и больше) скорость разработки; а можно нанять толпу лентяев за пачку Анакома и удивляться, что ничего не ускорилось. В общем, берите пока наиболее простой расчёт от меня и накладывайте его на свой реалии.

Если разделить значения в графике SOA на 5, то получится тоже очень интересный график:

Во-первых, сразу видно, что за то же самое время мы смогли сделать значительно больше фич. Да, часть из них не требуются в Monolith'е (та же "Отсыпка территории" или военные исследования), но всё же факт есть факт. Если бы не это не приходилось бы делать, то можно было увеличивать число сотрудников команды не на 5, а на 3, но это уже утопическая лирика.

Во-вторых, как только мы в начале игры закончили Monolith-времянку, мы почти сразу же получили не хилый буст по фичам, который и не снился в Monolith'е - по сути мы его догнали по скорости. Но потом начался этап, когда нужно было поднимать производство новых видов Колб и появилась необходимость активно расширять Шину, создавая новые производства. И так до следующего буста по кругу.

В общем, это та самая "лесенка", о которой я предполагал ранее - на шаге 17 мы получили буст от Зелёных Колб и быстро изучили всё нужное, но потом появился простой до шага 65, где пришлось ждать наладку производства Чёрных колбы. Подобное было потом на шаге 79 - от Синих колб; на шаге 111 - от Фиолетовых; на 123 - от Желтых. Как то так.

Ещё можно заметить, что у нас в SOA начались первые исследования немного раньше, чем в Monolith'е - связано это с тем, что в SOA я строил временный монолит как попало (лишь бы обеспечить себя ресурсами на первое время), а потом просто всё снёс. В то же время в попытках построить Monolith я изначально пытался все строить более-менее правильно, держа в голове, что всё это будет расширяться.

В общем ситуация странная: относительно производства простоев нет и всё идёт в сторону Прекрасного Продукта, но относительно Бизнеса мы прямо очень сильно контрастируют на фоне Monolith'а по срокам и бюджету.

Ну и напомню, что из этих 5-и человек двое будут работать полностью с Шиной - это те самые 30-40% времени на обслуживание Шины, что мы высчитали ранее. Остальные 3 человека поделят между собой обслуживание производств (их 98 штук), поставку сырья (их 16 штук), а так же решению ИБ- и Бизнес-вопросов. Такие дела.

Agility

Тут мы оцениваем, насколько раньше/позже у нас произошли важные события в нашем Продукте.

Таблица по производству и прочим событиям:

Событие

Время для Monolith

Время для SOA

Первая лаборатория (временная)

не применимо

00:27:48

Временный Монолит закончен

не применимо

00:53:56

Начало создания основной архитектуры

не применимо

01:01:45

Первая лаборатория

00:52:56

04:23:26

Заканчивается стартовая железная жила - прошлось вести новую жилу

неизв

06:41:36

Первый конфликт с ульем (мешают строить)

не применимо

07:46:42

Второй конфликт с ульем (мешают строить)

не применимо

08:03:27

Закончилась стартовая железная жила

неизв

10:14:53

Производство зелёных колб

01:12:27

10:45:49

Заканчивается стартовый уголь - прошлось вести новую жилу

неизв

13:24:36

Производство черных колб

02:24:34

17:26:03

Заканчивается стартовая медная жила - прошлось вести новую жилу

неизв

18:04:07

Первая атака жуков

08:10:37

25:26:04

Организовано ЖД производство

02:22:17

25:53:13

Начато строительство ЖД

03:38:32

29:35:23

Запущена ЖД (железо)

06:35:07

31:54:15

Убрано старое производство (железо)

06:48:43

34:34:15

Запущена ЖД (медь)

неизв

35:00:44

Запущена ЖД (камень)

19:32:27

41:01:31

Производство красных конвейеров

01:44:19

43:50:51

Запущено выкачка нефти

09:08:44

54:00:33

Производство пластмассы

10:04:01

61:52:19

Производство серы

неизв

62:21:09

Производство красных микросхем

неизв

64:27:02

Производство синих колб

10:43:45

67:33:56

Перенесена электростанция #1

не применимо

72:00:40

Перенесена электростанция #2

не применимо

73:28:38

Производство мазута, дизеля и смазки

11:04:12

73:35:46

Производство соляной кислоты

11:20:06

79:43:12

Добыча урана

12:03:17

79:59:50

Производство фиолетовых колб

12:59:12

85:22:43

Кончилось электричество (уголь)

не применимо

90:19:01

Восстановлено электричество

не применимо

91:15:00

Поезда переведены на ракетное топливо

16:11:20

92:26:58

Переработка урана

12:20:23

93:40:32

Процесс обогащения урана запущена

15:33:37

94:00:02

Запущена АЭС

18:52:05

99:51:49

Запущено производство синих микросхем

16:35:14

103:13:26

Запущено производство конструкций малой плотности

неизв

107:37:10

Отказ от сжигания угля

22:20:34

110:48:18

Запущено производство жёлтых колб

18:02:56

115:00:36

Запущено производство блоков управления ракетой

19:15:50

115:48:54

Запущено производство ракетных шахт

20:56:03

118:35:23

Запущено производство частей ракет

21:01:03

119:40:38

Запущено производство спутников

23:19:52

119:58:51

Ракета собрана

23:18:24

122:41:01

Запущена ракета

23:47:36

122:41:41

Переключено переплавка железных и стальных плит на ЖД

07:27:15

не применимо

Новая атака жуков (от загрязнения)

14:11:00

не применимо

Опять же, некоторые события случались только в Monolith'е или только в SOA, поэтому график будет немного "рваным":

Читать это график следует следующим образом: выбираем нужно событие и смотрим, когда оно было в Monolith, а когда в SOA и, отдельно, в SOA/5 (с увеличенной в 5 раз командой). Например, тут можно заметить, что первую атаку жуков мы спровоцировали значительно раньше Monolith'а, а так же значительно позднее запустили ЖД. Зато запустили ракеты и АЭС мы почти одновременно при в случае "SOA/5". Ну и с чистым SOA сравнивать смысла нет т.к. в этом случае позднее будет абсолютно всё.

В общем:

  • Запуск АЭС - одновременно, при увеличении количества команды в 5 раз;

  • Отказ от сжигания угля - одновременно, при увеличении количества команды в 5 раз;

  • Запуск ракеты - одновременно, при увеличении количества команды в 5 раз.

Можно ли считать тогда считать, что в плане финальных целей SOA идентичен Monolith'у, но просто требует больше "рук"? Вопрос спорный и поэтому придётся посмотреть ещё на другие особенности Архитектурного стиля SOA.

Configurability

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

Если в Monolith'е мы могли наращивать производство чего-либо в ущерб другому, то теперь на это тратится только площадь и электроэнергия, а само перенаправление не запутывает конвейера на заводе - мы просто подключаем его к Шине по аналогии с остальным. Иными словами - процесс больше похож на масштабирование внутри приложения, чем на переписку кода.

Цифры прироста, правда, не особо впечатляющие:

Конфигурирование

Прирост производства для Monolith

Прирост производства для SOA

Красные микросхемы на синие колбы

222,22%

Зелёные микросхемы на модули управления ракетой

900,00%

Железные плиты на стальные плиты

150,00%

Добавление завода шестерёнок

325,53%

Добавление завода зелёных микросхем

240,96%

Добавление завода красных микросхем

185,34%

Добавление завода кабелей

175,00%

Добавление завода пластмассы

220,00%

Добавление переплавки железа

185,19%

Добавление переплавки меди

203,45%

То есть в SOA любое реконфигурирование даёт прирост, стремящийся к удвоению, но при этом работает не в ущерб другим производствам. В Monolith же, в виду более простой Архитектуры, можно сделать прямо впечатляющий прирост, но только путём отключения или значительного уменьшения другого(их) производств(а).

Cost

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

Собственно, большие проблемы с Жуками связаны исключительно с занимаемой площадью приложения. Сравните его с Monolith'ом:

Параметр

для Monolith

для SOA

Площадь общая (любые постройки)

3402 m2 (100%)

4466850 m2 (131300%)

Площадь полезная (производственные здания)

2425 m2 (100%)

1831119 m2 (75510%)

Энергопотребление

125 МВт (100%)

283 МВт (226%)

Это ужасает - площадь приложения на SOA больше примерно в тысячу раз Monolith'а и всё это вина Шины. Хотя при этом потребление электроэнергии сравнительно маленькая - связано это с тем, что не все производства в нём работают одновременно (см. карту загрязнений).

Собственно, подобные площади очень сильно сказались на следующем эксперименты - Deployability.

Deployability

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

Я то думал, что за счёт того, что моё производство всяких строительных расходников многократно превышает то, что было в Monolith'е и я смогу значительно быстрее развернуть второй экземпляр Завода. Но, к сожалению, сам Завод разросся до таких объёмов, что получилось ещё хуже, чем в Monolith по времени:

Событие

для Monolith

для SOA

Нехватка конвейеров

200 минут

-

Запущено второе производство конвейеров

248 минут (100%)

1700 минут (685%)

Полный запуск второго завода

473 минут (100%)

2467 минут (521%)

В общем и целом, большие объёмы дали о себе знать - на то, чтобы развернуть копию завода ушло в 5 раз больше времени, чем на Monolith. Эта цифра связана не со сложность приложения, а исключительно с большим объёмом - большую часть времени я просто либо что-то строил по плану, либо ждал расходников.

Сохранение

Scalability/Perfomance/Testability

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

При тестировании производительности мы, как всегда, даём бесконечный буст сырья (железо, медь, нефть и прочее) и смотрим, какую производительность покажет производство Частей ракет и Спутников. Тут есть интересность: если в Monolith'е мы получали буст производства в течении нескольких минут, то в SOA на это уходит чуть меньше часа - сырьё долго идёт производственный путь с начала Шины до целевых производств.

На скриншоте видно, что мы подключили бесконечное сырьё ~54 минут назад, а производство начало уверено расти только ~4 минуты назад

Более того, если подождать ещё, то можно заметить, что оно ещё и медленно разгоняется и ждать стабилизации производства приходится достаточно долго - около 12-ти часов.

Тем не менее рано или поздно оно стабилизируется и можно снять параметры и сравнить с Monolith:

Производство

Производство базовое (контрольное)

При вертикальном масштабировании

При горизонтальном масштабировании

Части ракеты (SOA)

148 ед/час (100%)

200 ед/час (135%)

390 ед/час (263%)

Части ракеты (M-th)

99 ед/час (66%)

110 ед/час (74%)

192 ед/час (129%)

Спутник (SOA)

27 ед/час (100%)

32 ед/час (118%)

67 ед/час (248%)

Спутник (M-th)

2 ед/час (7%)

2 ед/час (7%)

3 ед/час (11%)

В качестве 100% мы берём контрольные измерения производства Частей ракет и Спутников от SOA и сравниваем его с масштабированием и цифрами от Monolith. Как видно, прирост производительности получился большой. Более того, здесь значительно лучше показывает себя вертикальное масштабирование, а вот горизонтальное не сильно лучше Monolith'а. Ещё радует значительный прирост производства спутников: не смотря на то, что в Monolith и в SOA у нас на них был только один единственный завод - за счёт обилия расходников его производство возрастает многократно.

Что по тестированию:

Производство

Производство базовое (контрольное)

Тестирование на бесконечный спавн Конструкций малой плотности, Блоков управления ракетами, Ракетного топлива и Спутников

Тестирование на бесконечный спавн Плат всех цветов, Медных, Стальных и Железных плит, Ракетного топлива, Статичных аккумуляторов, Солнечных панелей и Радаров

Тестирование на бесконечный спавн Медных, Стальных, Железных и Пластмассовых плит, Серы и Дизельного топлива

Части ракеты (SOA)

148 ед/час (100%)

1000 ед/час (676%)

335 ед/час (226%)

148 ед/час (100%)

Части ракеты (M-th)

99 ед/час (100%)

757 ед/час (764%)

100 ед/час (101%)

99 ед/час (100%)

Спутник (SOA)

27 ед/час (100%)

Вне учёта

81 ед/час (300%)

27 ед/час (100%)

Спутник (M-th)

2 ед/час (100%)

Вне учёта

47 ед/час (2350%)

2 ед/час (100%)

Время, затраченное на организацию тестирования (SOA)

04:52

17:10

20:38

Время, затраченное на организацию тестирования (M-th)

04:23

14:23

09:10

Выглядит подключение для тестирования примерно вот так:

В плане времени видно, что SOA более предсказуема чем Monolith т.к. чем более сырьевое производство мы делаем, чем больше мы на это время тратим. Но не из-за попыток придумать КАК подключить тестирование, а больше из-за выбора места КУДА подключить. Зато за счёт ширины Шины получается дать больше сырья и, соответственно, получить больше производительности.

Elacticity

Тут мы просто высчитываем некое число эффективности скорости разворачивания к фактическому приросту производительности для сравнения.

На основании Deployability и Perfomance, можно сказать, что за 2467 минут мы получаем прирост на 163% частей ракет и на 148% спутников. Итого, умножаем это:

  • Части ракет: 1.63х2467=4021.21

  • Спутники: 1.48х2467=3651.16

Для сравнения, в Monolith'е у нас были числа 444.6 и 236.5 соответственно - то есть в нём за меньшее время мы получили большее число производительности при Горизонтальном масштабировании, а значит Monolith эффективней SOA в этом плане.

Domain Partitioning

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

Основные зоны производства стоят параллельно Шине и, хотя они плотно находятся друг к другу по бокам, но вниз у каждого из них есть место для роста - собственно это помогло ранее сделать Вертикальное масштабирование. Так что как таковых плотно стоящих зон у нас не наблюдается, но и возможность расширения только в одну стороны сложно назвать "Хорошо разграниченной зоной". Думаю, что с этого момент введём новое состояние зоны "С ограничениями" - то есть расширяться можно, но не в любую сторону.

Итого:

  • Хорошо разграниченных зон: 16

  • Плотно стоящих зон: 0

  • С ограничениями: 98

Думаю, такое количество зон "С ограничениями" мы будем наблюдать только в SOA, но это не точно.

Что бесспорно, это у нас стало лучше, чем было в Monolith'е:

Abstraction Level

Тут мы высокоуровнево обозначаем части продукта по назначению и смотрим, как сильно оно перемешано:

Если проанализировать уровень абстракции, то тут в основном всё замечательно: Ресурсы добываются где-то в стороне, от ЖД начинается Шина и по всей её длине идёт Основной завод, изредка переключаясь на "Переработку ресурсов" и ещё реже на "Хранилище". На этом уровне всё выглядит достаточно комфортно для понимания принципа работы приложения, что нельзя было сказать про Monolith.

Сравните, ради интереса, с тем, что у нас было в Monolith'е:

Fault Tolerance

Тут мы пробуем сломать наш завод путём DDoS- и хакерской атак.

С жуками просто: они прорвали оборону через 125 минут. При этом под раздачу попал не сам завод, а точки добычи ресурсов и пути к ним. А без добычи ресурсов сырьё просто кончилось и всё встало.

С вторым вариантом (имитация DDoS) вышло интересней - на то, чтобы полностью застопорить работу завода путём посылания "паразитных" поездов (трафика), ушло 7:40:19 (почти 8 часов) времени.

По количеству поездов ситуация следующая:

Событие

для Monolith

для SOA

Базовое количество поездов

19 (100%)

40 (100%)

Проблема стала видимой

33 (173%)

109 (272%)

Началось снижение производительности производства

68 (357%)

219 (547%)

Полная остановка производства

110 (578%)

221 (552%)

Поскольку в данном Архитектурном стиле ЖД играет более значимую роль из-за своих объёмов, то и она оказалась более стойкой к большому количеству поездов. По сути, если не считать мелкие улучшения и проблему с кольцевой дорогой - производство упало только под конец, когда станции просто не могли обменяться друг с другом поездами из-за занятости обоих. Хотя в процентном соотношении разницы не очень много, конечно, но мы тут больше смотрим на количество поездов.

Deadlock на кольцевой дороге:

По финалу ЖД застопорилось примерно вот в таком виде - поезда просто упёрлись в установленный лимит составов на станциях и не могли двигаться т.к. им просто некуда ехать:

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

Сохранение

Общий вывод по SOA

Если сравнивать с Monolith'ом, то можно выделить следующие достоинства SOA:

  • Значительно больший запас производительности - продукт реально сможет как принять больше нагрузки изначально, так и иметь значительно больший прирост производительности при масштабировании. Плюс при запуске новой фичи она сразу же имеет возможность принять большую нагрузку "по умолчанию";

  • На описании продукта на уровне абстракций получается вполне логичная и понятная схема взаимодействия вида [Сырьё]->[ЖД]->[Шина]->[Обработка сырья]->[Шина]->[Производство]->[Шина]->[Ракета]. Так же это очень хорошо сказывается на возможности добавления новых производств в Продукт - всегда просто сообразить, куда добавить новое производство (спойлер: тупо в конец);

  • Удобство тестирования - подключить к какой-либо части Шины бесконечные ресурсы для проверки производительности значительно проще осуществить, чем в Monolith'е;

  • Получается более развитая система точки входа для пользователей в плане нагрузки, включая DDoS - при этом она получается такой сама собой просто эволюционно по мере создания Продукта;

  • Значительно проще выполнять Вертикальное масштабирование т.к. достаточно скопировать текущую схему заводов и либо дополнить его текущим подключением к существующему заводу, либо отдельно подключить его к Шине. Не идеально, конечно, но точно лучше того, что было ранее.

Но недостатков у неё имеются:

  • Значительно более поздний запуск первых пользователей из-за технологических аспектов Архитектуры, что вызывает множество вопросов со стороны Бизнеса относительно сроков;

  • Необходимость тратить много человеко-часов и ресурсов на поддержание работы Шины - это сказывается на увеличенный Бюджет, чему Бизнес рад не будет. Сама работа оказалась не сколько сложной и запутанной, сколько большой и монотонной;

  • Получается очень большое приложение, что негативно сказывается как на Горизонтальном масштабировании, так и на необходимость тратить Бюджет на дополнительные серверные ресурсы. При этом прирост производительности при масштабировании не идёт ни в какое сравнение с получаемым увеличением производительности.

Как говориться, "Долго, дорого, качественно". Получается, что все недостатки SOA связаны именно с Бизнесом и его неудовлетворённым желанием выпустить продукт быстро и дёшево - именно поэтому SOA имеет столь негативную славу. Если Бизнес захочет новую фичу - он будет привлекать как минимум двух программистов (Шины и Сервисов) и ещё достаточно долго ждать, когда они договорятся и сработаются между собой.

Да, у нас получается достаточно структурированное и производительное приложение и любой программист бы им гордился, но если со стороны Бизнеса эти расходы не окупятся - приложение уйдёт в раздел "Провальные". Так что применять SOA стоит только при отсутствии конкуренции, спешки и необходимостью большого запаса производительности.

В следующей передаче - Service-Based Architecture или SeBA

В следующей статье мы продолжим идти по хронологическому порядку развития Архитектурных стилей и перейдём на Основанную на сервисах архитектуру (Service-Based Architecture или SeBA). Исторически команды, познав горький опыт использования SOA начали думать, что делать дальше и решили (наконец-то) заменить громоздкую шину на REST API.

Что из этого у них получилось - узнаем в следующей статье! А пока я временно прощаюсь с вами, душевно благодарю за прочтение моей работы и ухожу опять на полгода запускать новую игру с нуля - пожелайте удачи, ибо я вам этого тоже желаю ;)

Tags:
Hubs:
Total votes 91: ↑90 and ↓1+89
Comments50

Articles