Андрей Парамонов "MediatR не нужен"

  Рет қаралды 10,248

DotNetRu

DotNetRu

Күн бұрын

Пікірлер: 38
@mibli2935
@mibli2935 Жыл бұрын
Мне было интересно прослушать Ваш доклад и очень приятно то что Вы, в качестве отправной точки, рассказали о вкладе Максима Аршинова в развитие этой очень важной темы для разработчиков вашей страны. Я могу поделиться своей историей. Я, как менеджер проекта и «представитель заказчика из-за рубежа», работал с Максимом над большим проектом более четырех лет. Со стороны команды возглавляемой Максимом в проекте участвовали не менее 10 человек, в разные периоды времени количество разработчиков менялось. Максим реализовал именно ту схему которую он подробно описал в своем докладе. Я думаю что людям прослушавшим его доклад не надо рассказывать о его высоком профессионализме; поверьте мне на слово что он не только блестящий профессионал но и прекрасный человек, менеджер и руководитель группы. Итак - проект на backend-е был реализован по схеме доклада. У разработчиков в России не было проблем найти ошибку, понять логику кода и т.п. В конце моего участия в проекте в нашу команду «тут» были взяты двое местных разработчиков. И вот у них начались проблемы, но какого рода? Они были по техническому уровню несколько ниже разработчиков команды Максима и поэтому в течении месяца-двух они вносили баги из-за непонимания структуры middleware. Если бы, до начала работы, их бы провели по схеме и рассказали как это запроектировано, проблем бы не было, но они отказались по причине "сами-с-усами". Они разобрались в конце концов, но ценой нескольких очень неприятных ошибок в production, и, кстати говоря, непрерывно жалуясь на сложность, непонятность и "зачем так сложно хотя можно просто". Я хотел рассказать о практическом опыте в котором принимал участие лично я. Я не могу назвать вам этот проект, и Максим тоже не сможет по условиям NDA, но, учитывая срок разработки и количество разработчиков, вы сами сможете представить об'ем кода. Бизнес логика была очень и очень непростая.
@nikolay4362
@nikolay4362 Жыл бұрын
zen of pyton очень крутая философия - там сказано что "явное лучше неявного" и оно так и получается по сути))
@augustine582
@augustine582 Жыл бұрын
ну так что бы не было загадкой давайте все писать в контроллере, а ?
@maxm1079
@maxm1079 Жыл бұрын
все новое когда - то забытое старое )
@DoubleQuadruple
@DoubleQuadruple Жыл бұрын
Фи, контроллеры. Прямо в Main через Minimal API!
@zodchiygigas6098
@zodchiygigas6098 Жыл бұрын
Чем не устраивает новый подход который выкладываем сами MS в своих примерах? Ендпоинты+обертка для агрегатов в виде репозитория, а для стремных запросов и сложных фильтров использовать спецификации к конкретным агрегатам. Минимум инфраструктурного кода, больше бизнес логики.
@andrewbondaryuk
@andrewbondaryuk Жыл бұрын
@@DoubleQuadruple Для микро да, для больших монолитов с десятками/сотнями эндпоинтов - бррр... Ну или решить этот вопрос раз и навсегда - json rpc! 😀😀😀
@bugmakerah
@bugmakerah Жыл бұрын
Не совсем ясно кто мешает расположить Request, Handler и Validator в одном классе. Тогда при одном взгляде на код становится все очевидно + IDE помогает в навигации Например у нас домен сотрудников: Feature folder - Employees; Class - AddEmployee; Employees/AddEmployee.AddEmployeeCommand Employees/AddEmployee.Handler Employees/AddEmployee.Validator Вызов из контроллера будет выглядеть так: var result = await Send(AddEmployee.AddEmployeeCommand("test-name")); При проваливании в эту команду мы сразу увидим и хендлер и валидатор в одном файле.
@eugenes9602
@eugenes9602 Жыл бұрын
То есть любой разработчик, когда пишет новый метод, реализующий новую логику, вместе ним должен написать 125 явных вызовов ортогональных абстракций (скоупы логгинга, метрик, валидации, еще черте что). Каждый раз для каждого нового метода, потому что вам лень посмотреть в стартапе порядок регистрации пайплайнов? Ну отличное решение, чо. Давайте тогда сразу вернемся к процедурному программированию, там одна большая портянка на 100500 строк и все понятно, кто где чего вызывает.
@andrewbondaryuk
@andrewbondaryuk Жыл бұрын
Добро пожаловать в гошники! 😀
@shaqull
@shaqull 11 ай бұрын
С интерсептeрами+сорсгенераторами можно будет добавлять сбор метрик/логов/валидации/еще черте что без mediatr
@eugenes9602
@eugenes9602 11 ай бұрын
@@shaqullЕсть еще 100500 вариантов добавления ортогональных ответственностей и в итоге получится тот же самый медиатр, вид сбоку. И зачем? Чтобы добавить в свой проект кучу плоходокументированного и никем не поддерживаемого инфраструктурного кода?
@gurustron
@gurustron Жыл бұрын
"В индустрии использование MediatR считается хорошим тоном." - нет, не считается)
@Kefir0
@Kefir0 Жыл бұрын
+1, это зашквар, инфа 100%
@zodchiygigas6098
@zodchiygigas6098 Жыл бұрын
Никогда не понимал людей которые любят использовать MediatR. Мне кажется, что всегда есть поход лучше и проще.
@iamprovidence-xj5wf
@iamprovidence-xj5wf Жыл бұрын
например?
@zodchiygigas6098
@zodchiygigas6098 Жыл бұрын
@@iamprovidence-xj5wf всегда.
@iamprovidence-xj5wf
@iamprovidence-xj5wf Жыл бұрын
@@zodchiygigas6098 какой бы подход ты посоветовал использовать в качестве замены MediatR?
@omgoood
@omgoood Жыл бұрын
Просто булькнул и ушёл..
@andrewbondaryuk
@andrewbondaryuk Жыл бұрын
Нет лучше/хуже. Есть явно, не явно, удобнее, сложнее :)
@ruslanra2356
@ruslanra2356 Жыл бұрын
Наверное надо просто хорошенько во всем разобраться, а уже потом выступать с вопросом "А что-то тут мне не понятно"
@АлексейГорбунов-ь1э
@АлексейГорбунов-ь1э Жыл бұрын
🤦‍♂️
@viktoralferov2874
@viktoralferov2874 Жыл бұрын
Богохульство, Ересь - батон крошить на MediatR! Предать анафеме! )
@vitaliyleschenko
@vitaliyleschenko Жыл бұрын
Я смотрю что современным программистам совсем сложно жить стало. То им сложно, это им не понятно. Скорее бы вас уже ChatGPT заменил и остались только нормальные программисты.
@okke00
@okke00 Жыл бұрын
Ты не поверишь, но вся история IT крутится вокруг борьбы со сложностью. Так то можно и на ассемблере написать все что угодно)
@vitaliyleschenko
@vitaliyleschenko Жыл бұрын
@@okke00 можно. Но это не значит что если вам что-то не понятно, то это именно сложно. Большенство чужих решений вам изначально могут показаться не понятными. Всегда можно спросить почему так, а не иначе. В чем была причина написать именно так. Если вы на это не способны - вам сложно.
@okke00
@okke00 Жыл бұрын
@@vitaliyleschenko Сложность в ПО довольно редко связана именно с доменом, как правило, это искусственная сложность, которая вызвана или несовершенством средств разработки или неумением людей писать поддерживаемый код. Первая проблема решается естественным эволюционным путем, именно поэтому мы сейчас и не пишем все на коболе или фортране каком-нибудь. Со вторым сложнее, т.к. всегда есть определенный процент разработчиков, которые считают, что на работе им надо писать код так, чтобы доказать остальным какие они крутые. Да, бывают ситуации, когда действительно сложное решение оправдано, но чаще это именно история про то, как условный Петя хотел потешить свое эго или просто развлечься. Ну и да, хорошей практикой является документировать свои решения, а не передавать знания как древние сказители, из уст в уста. Обычно если человек, неспособен описать почему было принято именно такое решение в проекте, то это решение не сильно обосновано.
@polarbar780
@polarbar780 9 ай бұрын
Виталий был известный дворник, но по ночам в комментах срал 😁
Players vs Pitch 🤯
00:26
LE FOOT EN VIDÉO
Рет қаралды 125 МЛН
Perfect Pitch Challenge? Easy! 🎤😎| Free Fire Official
00:13
Garena Free Fire Global
Рет қаралды 85 МЛН
Андрей Парамонов, Антон Оникийчук - MediatR не нужен
59:53
DotNext — конференция для .NET‑разработчиков
Рет қаралды 3,6 М.
«Осень». Самая большая загадка Windows XP
14:36
Девять десятых
Рет қаралды 1,2 МЛН
Денис Цветцих - Модульный монолит вместо микросервисов: Как, когда и зачем
1:00:37
DotNext — конференция для .NET‑разработчиков
Рет қаралды 6 М.
Players vs Pitch 🤯
00:26
LE FOOT EN VIDÉO
Рет қаралды 125 МЛН