Марк Шевченко - Микросервисы на C#

  Рет қаралды 28,089

TverIO

TverIO

4 жыл бұрын

Марк Шевченко на Tver.io Backend Meetup 21 ноября.
Посмотрим на C# с точки зрения практики. Интересные для нас возможности языка - это деревья-выражений и async/await. Богатая библиотека позволит за считанные секунды подготовить каркас веб-приложения или создать миграцию базы.
Сравним микро-сервисный подход с другими распространёнными решениями: трёхзвенной и гексагональной архитектурами, чистой архитектурой Роберта Мартина и DDD. Узнаем, живёт ли C# в Linux и Docker. Подсказка: да, прекрасно живёт, и давно.
Немного поговорим о ползучей практике: что, как и в каком порядке. Придём к выводу, что C# для микро-сервисов - прекрасный выбор.

Пікірлер: 34
@grafbcn
@grafbcn 2 жыл бұрын
Спасибо за доклад. Особенно за тонкости асинхронности на C#
@konstantinkav.9975
@konstantinkav.9975 2 жыл бұрын
Спасибо, отличное видео!
@samnihao6943
@samnihao6943 3 жыл бұрын
32:05 про микросервисы
@samnihao6943
@samnihao6943 3 жыл бұрын
Спасибо. Было бы здорово, если бы ссылки были в описании под видео.
@ivantut9210
@ivantut9210 Жыл бұрын
Кучу время потратил на поиск качественного объяснения и только спустя год видео появилось в рекомендациях.
@nikiv2688
@nikiv2688 3 жыл бұрын
Полезно
@AntonSkworc
@AntonSkworc 3 жыл бұрын
Очень хороший доклад! С шарпом работаю уже довольно давно, но всё равно послушать было очень интересно. На мой взгляд, про микросервисы автор рассказал достаточно доступным языком, и в то же время интересно. А по поводу LINQ: его в основном используют благодаря методам расширения. В результате такой код выглядит достаточно красиво. Интересно было узнать, что именно в C# впервые применили концепцию написания запросов подобного рода в самом коде (в других языках аналогов не было). Автору спасибо за хороший и интересный доклад!
@user-bd3ij4op5k
@user-bd3ij4op5k 3 жыл бұрын
Вообще это не "ленивые" запросы, а "отложенные" . В целом было интересно послушать , хотя немного шокировало поначалу список "почему не шарп для бэкенда" ))
@MisterGenix
@MisterGenix 4 жыл бұрын
Спасибо, было интересно послушать. Про базу вот только не понял - говорите, что у каждого микросервиса должна быть своя база, но вместе с тем вы собирали данные в монго на одном микросервисе, а потом другими лазили в нее и что-то выбирали.. Или это про то, что обращения к этой базе должны проходить только через этот микросервис? И второй вопрос - если все-таки у нас в огромном приложении используется один единственный сервер, то стоит ли в пределах одного сервера выделять какие-то микросервисы на Kestrel или их суть только в том, чтобы можно было отсоединить физически на другой сервер?
@markshevchenko
@markshevchenko 4 жыл бұрын
Спасибо за вопросы. Сначала отвечу про базы и микросервисы. В идеале -- у каждого микросервиса своя база. Проектировать и делать надо так. Но диспциплина у нас инженерная, иногда приходится срезать углы. Бывает, что не хватает производительности в конкретном месте, или нужна согласованность данных, то есть нужна транзакция для двух-трёх операций. Мы можем решить, что в данном случае можно нарушить изоляцию сервисов и залезть в базу к соседу. Мы в таких случаях всё равно себя ограничивали: доступ в чужую базу делали только по чтению.
@markshevchenko
@markshevchenko 4 жыл бұрын
Вопрос про приложения и сервер. Микросервисы облегчают масштабирование. Если производительности сервера не хватает, вы ставите рядом второй. Вопрос: можно ли будет без труда разбить приложение на две части и разнести на два сервера. Нет. Это не происходит просто так. Чтобы можно было масштабировать приложение, его надо разбить на слабо связанные части. Тогда можно будет без труда запускать их на одном сервере или на нескольких. Тут есть хитрость. Если у вас большое приложение, его всё равно лучше разбивать на части, которые в DDD называют ограниченными контекстами (bounded contexts). Поставьте ограничение: контексты видят друг у друга только интерфейсы, события и DTO. Под интерфейсами я понимаю конкретно интерфейсы C#, ключевое слово interface. DTO -- простые объекты без поведения, чисто открытые данные. Для начала ваши контексты могут быть просто сборками, которые запускаются в рамках одного домена .NET, но в случае необходимости вы без труда (за условные две недели) сможете превратить их в микросервисы, не переписывая весь остальной код. Просто поменяете реализацию интерфейсов. События сделаете через очереди сообщений (message queue). Если делать так, вы можете разнести большое приложение на независимо масштабируемые микросервисы в случае необходимости.
@MisterGenix
@MisterGenix 4 жыл бұрын
@@markshevchenko спасибо за ответы, в принципе, эта идея и прослеживалась в видео - микросервисов даже если в проекте нет, они должны быть "в уме" в виде bounded context'ов )
@crazy_fedor
@crazy_fedor Жыл бұрын
Интересно, но очень мало про микросервисы :(
@vborovikov
@vborovikov Жыл бұрын
что-то похожее по теме начинается с 38:00 минуты!
@VasilenkoYaroslav
@VasilenkoYaroslav 4 жыл бұрын
Спасибо за доклад. Как по мне про С# лучше было не расказывать, все не расказать за такое краткое время. Для одного потока выделяеться стек в 1 мб а не 10.
@markshevchenko
@markshevchenko 4 жыл бұрын
Спасибо за отзыв. Учту. Хотелось охватить всё, но не успел. Полная версия доклада на полтора часа. Про стек -- ошибся, спасибо, что поправили.
@SugarDiDi
@SugarDiDi Жыл бұрын
C# Рулит!
@shaqull
@shaqull Жыл бұрын
Простите, не удержался от критики :) Agile это про то, что мы сразу признаем - мы допустим ошибки, мы НЕ знаем как сделать, мы НЕ будет заниматься исследованием и длительным планированием, а сразу начнем делать, но мы будет это делать гибко держа руку на пульсе. Микросервисы это тоже про гибкость, но только для бизнес логики - если надо что-то внедрить, то бизнес не хочет быть зависимым от независящих факторов, которые не связаны с его новой логикой, но которые появляются в монолите, т.к. риск спутанности новых фич велик и надо ждать стабильную версию всей системы А у вас через слово: "вам надо сесть и договорится; надо сразу сделать правильно" Эти согласования взаимодействий будут сильно тормозить внедрение любой бизнес логики. При этом необходимость микросервисов обосновывается возможность обрабатывать 1 млрд запросов, а что мешает монолиту их обрабатывать, их же можно 5-10 штук запустить?
@MyPomoshnik
@MyPomoshnik Жыл бұрын
Так и есть. Но то что Вы описываете дороже в разы и называется экстремальным прототипирование - пилим сразу бизнес-логику, а потом переписываем полностью инфраструктуру.
@user-bw9kk2se7q
@user-bw9kk2se7q 4 жыл бұрын
Отличный доклад
@alexgrinberg1888
@alexgrinberg1888 3 жыл бұрын
Был удивлён , что интро на с# представлены сразу с LINQ. Для новичка это очень сложно понять. Вообще этот курс я бы построил для бэкенд програмеров.
@hysapod
@hysapod 3 жыл бұрын
Так ведь это и есть для бекэндеров)
@milovidov42
@milovidov42 4 жыл бұрын
Дерево выражений это конечно очень мощная технология но рассказывать людям эту технологию как введение в C# это конечно жесть.
@superspy2008
@superspy2008 3 жыл бұрын
удивился, почему он про Emit не рассказал. Самое оно для спящих студентиков в зале
@user-hc9qs6fj7m
@user-hc9qs6fj7m 2 жыл бұрын
Скажем так, если бы мне сразу освятили и сказали "братанчик, почитай что такое LINQ и лямбды" (как оно и было) - я бы .... я бы ничего не понял как и не понял до этого. Ладно. Ты прав, я передумал ахахахах
@user-wu5id5cx8v
@user-wu5id5cx8v 11 ай бұрын
Докладчик молодец. Вопросы - пиздос не в тему. Кроме последнего. Последний хороший. Разбивать систему - не всегда лучшее решение. А вот независимая, устойчивая система - вот к чему нужно стремится. Атомарность, как можно меньше связности.
@timur2887
@timur2887 Жыл бұрын
галопом по европам... когда всем этим занимался, то понимаешь, о чем речь.... а по глазам в аудитории очевидно, что более половины ничего не поняли)
@TinTaBraSS777
@TinTaBraSS777 2 жыл бұрын
опять часы пустого безсмысленного свистежа )
@maksimsergeevich5939
@maksimsergeevich5939 4 жыл бұрын
Странно что не упомянут Java, как наилучший инструмент для написания бекенда.
@AlekseiChel
@AlekseiChel 3 жыл бұрын
Потому что C# лучше?
@samnihao6943
@samnihao6943 3 жыл бұрын
Прям наилучший?)
@maksimsergeevich5939
@maksimsergeevich5939 3 жыл бұрын
@@samnihao6943 ну вообще хз, я так пизданул просто) я вообще на php / JavaScript пишу))
@samnihao6943
@samnihao6943 3 жыл бұрын
@@maksimsergeevich5939 да и я вообще-то искал котиков, не знаю, как на это видео попал)
@maksimsergeevich5939
@maksimsergeevich5939 3 жыл бұрын
@@samnihao6943xD
small vs big hoop #tiktok
00:12
Анастасия Тарасова
Рет қаралды 8 МЛН
Final muy inesperado 🥹
00:48
Juan De Dios Pantoja
Рет қаралды 17 МЛН
Пробую самое сладкое вещество во Вселенной
00:41
Climbing to 18M Subscribers 🎉
00:32
Matt Larose
Рет қаралды 32 МЛН
Вопросы собеседования на C# программиста
21:04
Програмысли Влог
Рет қаралды 62 М.
async/await в ASP.NET Core. Асинхронный код
27:42
Семен Алексеев
Рет қаралды 28 М.
small vs big hoop #tiktok
00:12
Анастасия Тарасова
Рет қаралды 8 МЛН