Тёмный

Что на самом деле представляет из себя монолит в архитектуре программы? 

S0ER
Подписаться 107 тыс.
Просмотров 14 тыс.
50% 1

#soer #itubeteam
Основной канал для общения и публикации новых видео - Телегарм - t.me/softwareengineervlog
Спонсорство - donate.s0er.ru
Сайт платным контентом - soer.pro
Зеркало для видео Дзен Видео - zen.yandex.ru/id/5f578bdf22e2...
GitHub - github.com/soerdev
Чат для программистов - / discord
Группа ВК - codeartblog

Опубликовано:

 

2 мар 2020

Поделиться:

Ссылка:

Скачать:

Готовим ссылку...

Добавить в:

Мой плейлист
Посмотреть позже
Комментарии : 86   
@user-td6vu1hh3y
@user-td6vu1hh3y 4 года назад
soer батя, самый опытный и зрелый it-ютубер; если честно ни бороду, ни остальных не могу серьезно воспринимать
@jorikvartanov8063
@jorikvartanov8063 4 года назад
Ербол Утегенов Поддерживаю, Соер Настоящий программист в полном понимании этого слова
@deniskoeppen
@deniskoeppen 3 года назад
Ну у Бороды и формат другой
@deniskoeppen
@deniskoeppen 3 года назад
В МСА разве нет проблем с физ. и лог. моделями данных?
@ronnie_rocketo
@ronnie_rocketo 4 года назад
ну наконец то видосы, я уже думал что канал заброшен. Один из немногих кого я смотрю. Было бы обидно...
@dmitrypichugin7449
@dmitrypichugin7449 4 года назад
Очень достойно. Так просто описать такие сложные понятия, дорогого стоит.
@socketam4524
@socketam4524 Год назад
Действительно очень хорошее объяснение, по делу и с реальными примерами. Спасибо!
@zcbesaba
@zcbesaba 4 года назад
с возвращением, продолжай, хороший контент.
@user-kk7ib8hu3v
@user-kk7ib8hu3v 4 года назад
Очень интересно. Спасибо!
@lightlocdog
@lightlocdog 4 года назад
топчик, кратко и понятно, спасибо
@vitiok78
@vitiok78 4 года назад
Очень интересно, спасибо! Давно хотел подобной информации к размышлению
@TotalCom4
@TotalCom4 4 года назад
Попробуйте почитать еще Боб Мартин "Чистая архитектура " 2017г., если конечно не читали, там даже с примерами из жизни.
@kianmeli
@kianmeli 4 года назад
Спасибо за тему!
@ilnurryazhapov9377
@ilnurryazhapov9377 4 года назад
Почаще выпускай видео, очень интересно
@absenteg
@absenteg 4 года назад
Помимо распределения нагрузки микросервисная архитектура позволяет еще и обеспечивать переиспользование этих самых сервисов. То есть если у компании несколько проектов в которых требуется реализация одинаковой и сложной бизнес-логики, то микросервисный подход будет вполне оправдан.
@theman5628
@theman5628 4 года назад
Сначала не прочитал название канала в уведомлениях. Подумал шо какой-то ролик по сталкеру....
@AlexanderSavchenko91
@AlexanderSavchenko91 4 года назад
Зашел в комменты чтобы написать этот коммент хахахах
@oeaoo
@oeaoo 4 года назад
Мало кто умеет соблюсти разумную достаточность. А вот наплодить ненужных архитектурных сущностей за деньги заказчика и потом еще это обслуживать могут наверное все.
@rsakutin
@rsakutin 4 года назад
Отличное видео!
@user-xj2xs3mz9v
@user-xj2xs3mz9v 4 года назад
спасибо!
@michaelkronenberg3712
@michaelkronenberg3712 4 года назад
Расскажи тоже самое про облачную архитектуру где десятки разных микросервисов )
@originalbiketricks
@originalbiketricks 4 года назад
Круто, значит я не говнокод пишу, а монолит )
@fj8017
@fj8017 4 года назад
😄
@sixaxisization
@sixaxisization 4 года назад
:)
@RusBear1993
@RusBear1993 3 года назад
копролит
@MDunaev
@MDunaev 4 года назад
Спасибо, Соер, слушать интересно. Блики и отражения в очках -- отвлекают, мешают сосредоточиться.
@user-lt2vd2ue2e
@user-lt2vd2ue2e 3 года назад
И монолит можно проектировать так, чтобы выделение отдельных сервисов в будущем, если это потребуется, доставляло минимум боли. И жесткие связи и зависимости внутри монолитной системы можно успешно ограничивать (фасады, стратегии, Protected Variations/OCP, инверсия зависимостей). Другое дело, что у программистов зачастую недостаточно квалификации, чтобы так проектировать архитектуру. И недостаточно дисциплины, чтобы следовать всем необходимым правилам. А должность системного архитектора (тот кто и должен следить за всем этим) у нас почему-то не прижилась.
@Denis.Zhelnerovich
@Denis.Zhelnerovich 4 года назад
Спасибо за полезную информацию, что бы посоветовал почитать на эту тему?
@dev_zloi
@dev_zloi 4 года назад
Хороший архитектор должен предвидеть все возможности расширения системы и провести "невидимые" границы между компонентами. В идеале архитектура должна быть такой, чтобы можно было легко от монолитной перейти к микросервисной и наоборот.
@user-10248
@user-10248 4 года назад
Дмитрий Попов реальность обычно такова, что этот хороший архитектор появляется только тогда, когда уже наломали дров и сами не справляются. Потому что мало стартапов могут себе позволить нанять опытного архитектора на начальном этапе проекта
@dev_zloi
@dev_zloi 4 года назад
@@user-10248 ну а кто спорит, я написал про идеальный случай.
@olegnagaylenko132
@olegnagaylenko132 4 года назад
Картинка просто прекрасна
@dsalodki
@dsalodki 4 года назад
сейчас в решении (сборке всех проектов) столько проектов (длл) что сама среда разработки не выдерживает и перезагружается, хотя ОЗУ хватает. верное видео в целом. что бы понять что хотели написать, в каком проекте нужно было что-то исправить использовал VS code и поиск по всему... и правда много проектов, уровней в веб апи путает. а методы не отрефакторенные это вообще два часа провёл и не понял что ещё нужно поменять.
@JohnDoe-ji1zv
@JohnDoe-ji1zv 4 года назад
Soer на чем ты разворачиваешь сервисы ? Было бы интересно узнать. Спасибо за видео
@toperarley7777
@toperarley7777 4 года назад
Ничего не понял, но это было круто.
@fpv_am
@fpv_am 4 года назад
10:20 ЖИЗА ЖИЗА ЖИИИИИИИИИИИИЗАААААААААААААААААА
@user-10248
@user-10248 4 года назад
AntiBlog неистово плюсую. Потом ещё выясняется что разделили неправильно. И это обрастает костылями для того, чтобы это неправильное разделение компенсировать
@alexsokol9447
@alexsokol9447 4 года назад
Звук не совпадает с картинкой
@user-oi1zl6de8i
@user-oi1zl6de8i 4 года назад
Вам нужно обратиться в учреждение, где ставят диагнозы и выписывают рецепты.
@vyacheslavgvorus3883
@vyacheslavgvorus3883 4 года назад
Это нормально, визуальная информация обрабатывается дольше, на звук реакция быстрее, живи с этим фактом
@sixaxisization
@sixaxisization 4 года назад
@@user-oi1zl6de8i ....
@ostrov11
@ostrov11 4 года назад
Всему своё время и место
@feoktant
@feoktant 3 года назад
Что скажете о модульных монолитах на уровне кода?
@oqqa5295
@oqqa5295 4 года назад
Акторная модель в коде считается монолитом?
@fpv_am
@fpv_am 4 года назад
Я думаю, всё монолит, даже микросервисы, всё ровно же всё ото всего зависит, и идёт месседжинг между микросервисами
@fj8017
@fj8017 4 года назад
Ну, не совсем и не всегда. Возьмём в пример виджет отображения погоды на смартфоне. Если что-то пошло не так и виджет выбрасывает исключение, то можно этот виджет просто скрыть, на состояние всей операционной системы это влиять не будет. Но модульность можно организовать только на масштабных проектах, на небольших это сделать нереально, да и не нужно. Я, пока что, не сталкивался с ситуацией, где можно обойтись без монолитности.
@grigorii9019
@grigorii9019 3 года назад
+
@crutchmaster9637
@crutchmaster9637 3 года назад
s/#сложно/#сложна!/
@thomwhite4565
@thomwhite4565 4 года назад
Я правильно понял, что трехслойная архитектура, это монолит? Можете подробнее раскрыть вопрос ахрихетуры? трехслойную легче покрыть более точными тестами, чем монолит, следовательно проблемы выявляются еще на этапе разработки, проброс экзепшнов, так же дает более подробный стек и за счет того, что каждый слой делает свою работу, расширять и править его проще. Мне нужно соблюдать контракты между слоями, изменение которых не частое явление, а саму логику можно менять как угодно. - это как у меня получается. Но вот модульная архитектура, для меня теория.
@redserjogha
@redserjogha 4 года назад
Норм ликбез.
@drak0an
@drak0an 3 года назад
Эти 14 минут в своё время сэкономят миллион
@user-uw4my9tn1r
@user-uw4my9tn1r 3 года назад
На скорости 1.25, самое оно)
@sixaxisization
@sixaxisization 4 года назад
Жаль что про встраиваемые системы речь не идет :(
@MaximDementiev
@MaximDementiev 4 года назад
Если разбито на пакеты, то это уже не монолит, по-моему. Монолит - мне больше напоминает, например, ядро Линукса, которое собрано всё вместе, со всеми модулями, без возможности подгрузить ещё что-то. А в видео, похоже, идёт речь о непродуманности интерфейсов между слоями, когда рождается это самое "зацепление", когда взаимная реализация слоёв определяет этот интерфейс между ними. Нового ничего, к сожалению, не узнал.
@ME-ls9de
@ME-ls9de 4 года назад
Что значит "трех-слойное приложение"?
@ME-ls9de
@ME-ls9de 4 года назад
Апи-сервис-работа с бд?
@crutchmaster9637
@crutchmaster9637 3 года назад
Что значит "трёх"? Программисты не знают такого. Есть многослойное приложение. Это понятно.
@user-sz7kt8nf1m
@user-sz7kt8nf1m 4 года назад
Дык, а что ж такое монолитная архитектура и модульная.
@BASic_37
@BASic_37 4 года назад
Чет я тупой такой что ли? Но по-моему тема не раскрыта... Вот сегодня внес изменение даже не в трехзвенку, а в двух - изменил прямо на горячую хранимку (оптимизация запроса) и ничего не сломалось... А если, например, микросервис авторизации какой-нибудь выкючить/сломать и все пользователи не могут войти в систему, вот тебе и модульность... Дак в чем все таки принципиальное отличие?
@dev_zloi
@dev_zloi 4 года назад
Что вы подразумеваете по словом двухзвенка? Модульность характеризует независимую разработку и развертывание этих самых модулей. И понятное дело что каждый модуль играет разную роль в работоспособности системы, и скорее всего без одного модуля система не будет работать должным образом, но все же это модули и они обладают свойствами которые я написал выше.
@BASic_37
@BASic_37 4 года назад
@@dev_zloi В данном ПО отсутствует сервер приложений. Клиентское десктоп приложение работает напрямую с бд, причем основная бизнес логика вынесена в бд(про гениальность решения не будем...). В данном случае слой бд не зависит от клиента и с ней теоретически может работать другой клиент. Это модульность?
@dev_zloi
@dev_zloi 4 года назад
@@BASic_37 скорее всего в данном случае нет. Если приложении изначально разрабатываллсь не как модульное, то это монолит.
@BASic_37
@BASic_37 4 года назад
@@dev_zloi т.е. модульность это на уровне ощущения?
@S0ERDEVS
@S0ERDEVS 4 года назад
А при чем тут отказоустойчивость и модульность? Модульность - это про организацию совместной работы большого количества команд, независимое развертывание и тестирование, горизонтальное масштабирование.
@qr46654
@qr46654 4 года назад
Как можно "плавно" перейти от монолита к микросервисам?
@qr46654
@qr46654 3 года назад
@Румяные Блины микросервис, в данном контексте - это не маленький сервер или сервис с маленьким количеством услуг. "Микросервисы" - это порождение проблемы компилируемых языков (Java, c++, ...), а точнее способ снижения количества кода, который необходимо перекомпиллировать, чтобы внести изменения и быстрее вновь запустить приложение. В мире интерпретируемых языков типа рнр - такой проблемы просто не существует. Только сама перекомпиляция может занимать много времени
@oshyshko
@oshyshko 3 года назад
скорость 1.75
@feoktant
@feoktant 3 года назад
Кардинально неверное объяснение монолита. Разделение на монолит и SOA в первую очередь означало одну простую вещь - монолит отвечает за фронтэнд, а сервисы - нет. Старые java приложения с апплетами, jsp; Python Django, RubyOnRails вот типичные инструменты для монолитов. С приходом SOA, а в последствии и microservices, фронт в вебе начали рисовать не на сервере, а на клиенте, и произошел бум ajax. Есть жесткие связи, или нет - да и микросервис можно в спагетти превратить. Это квалификация разработчика. Модульный монолит лишь подразумевает, что это такой же монолит, отрисовывающий фронт, но на модулях. Хватит говорить о жестких связях. У вас может быть Джанго приложение, в котором будет N аппликейшионов, но общаться все эти аппы будут через сообщения по кафке. Слабо связанные компоненты, никак друг от друга не зависящие. А благодаря темплейтам - всё равно монолит, хоть и модульный. Мода жесткие связи называть монолиты пришла с хайпом вокруг микросервисов. SOLID, DDD, куча других практик как писать хороший жестко не связанный код был до этого десятилетия. Но нужен был хайп
@S0ERDEVS
@S0ERDEVS 3 года назад
Судя по всем у вас "фронтенд головного мозга", очень распространено среди людей, которые не застали программирование до появления веба. "Монолит - это приложение, которое отвечает за фронт"? Эм... надо запомнить этот тезис.
@feoktant
@feoktant 3 года назад
@@S0ERDEVS может быть и фронтэнд головного мозга) нужно заменить "фронтэнд" на "клиент", и всё станет на свои места. Клиент же может быть на чем угодно. Это разделение так же есть и в ядре ОС, и в компиляторе. И мне абсолютно непонятно как термин утратил первоначальный смысл.
@S0ERDEVS
@S0ERDEVS 3 года назад
@Anton Feoktistov "монолит отвечает за клиент"? Т.е. только клиент-серверные решения могут быть монолитными? Тогда с чего микросервисы не монолитны, у них нет клиента? Может все же откажетесь от этого тезиса? Очевидно же, что глупость сказали.
@feoktant
@feoktant 3 года назад
@@S0ERDEVS наоборот, клиент-сервисные решения по определению не являются монолитом. Томас Эрл, в его книге о SOA, с этого начинает, что есть сервисы и они выставляют АПИ, чаще всего rest или soap(книга 2005-го года). Монолит же не выставляет АПИ для процессинга данных. Как самый яркий пример я привел вебсервисы, которые сами рисуют view - django, ror, jsp, java applets. С приходом микросервисов монолит обрел негативный окрас, и начали говорить о жесткой структуре. Хотя до этого 10 лет все говорили о layers, solid, di и ddd, где и рассказывали как жесткости избежать
@S0ERDEVS
@S0ERDEVS 3 года назад
@Anton Feoktistov, чем дальше, тем веселее. Если ROR приложение выдало HTML, то оно монолит, если JSON, то нет?
@yaolegoleynik
@yaolegoleynik 3 года назад
Очень много умных слов монолит, архитектура, микросервисы и т.д. а тема монолита не раскрыта... За попытку объяснить 5, за объяснение 2 :(
@_RUDE_
@_RUDE_ 4 года назад
Чувак не вдавливай очки себе в лицо! Перед людьми все таки выступаешь!
@S0ERDEVS
@S0ERDEVS 4 года назад
Вообще-то перед камерой. Но поржал с твоего коммента.
Далее
Построил ДЕРЕВНЮ на ДЕРЕВЬЯХ!
19:07
Признаки монолита в коде
5:52
Просмотров 10 тыс.
Проектирую архитектуру чата
16:28