- Видео 103
- Просмотров 136 738
Андрей Суховицкий
Грузия
Добавлен 12 ноя 2014
КУРС EVENT SOURCING:
it-es-course.getcourse.ru/main
Автор курса: Андрей Суховицкий
Действующий разработчик ПО, работает над проектированием и разработкой высоконагруженных систем.
Последние 4 года создаю и провожу авторские курсы по микросервисной архитектуре, проектированию производительных систем и проектированию ПО в университете ИТМО и МФТИ.
В 2021 году получил награду как лучший преподаватель ИТМО.
it-es-course.getcourse.ru/main
Автор курса: Андрей Суховицкий
Действующий разработчик ПО, работает над проектированием и разработкой высоконагруженных систем.
Последние 4 года создаю и провожу авторские курсы по микросервисной архитектуре, проектированию производительных систем и проектированию ПО в университете ИТМО и МФТИ.
В 2021 году получил награду как лучший преподаватель ИТМО.
Буферизация запросов и когда она эффективна. HighLoad
Буферизация запросов и когда она эффективна. HighLoad | Больше постов о нагрузке с иллюстрациями на моем канале - t.me/andrey_threads
Обсуждаем, какие можно использовать тактики, если входная нагрузка на ваш сервис превышает его возможности. Отдельно рассматриваем технику "буферизации" запросов: что это? Когда она наиболее эффективна? Насколько широко применяется (спойлер - всегда и везде).
Обсуждаем, какие можно использовать тактики, если входная нагрузка на ваш сервис превышает его возможности. Отдельно рассматриваем технику "буферизации" запросов: что это? Когда она наиболее эффективна? Насколько широко применяется (спойлер - всегда и везде).
Просмотров: 520
Видео
Почему полезно иногда "наплодить" потоков
Просмотров 262Месяц назад
Больше постов о нагрузке с иллюстрациями на моем канале - t.me/andrey_threads Видео рассказывает о блокирующих потоки операциях, пассивном ожидании потоков и рассказывает, когда может быть полезно сделать сильно больше потоков, чем ядер процессора. Мы вычисляем количество потоков, исходя из времени выполнения операций и желаемой пропускной способности.
Потоки и многозадачность. Почему потоки стоит переиспользовать?
Просмотров 345Месяц назад
Регулярные посты о нагрузке, потоках и архитектуре с иллюстрациями на моем канале - t.me/andrey_threads Видео рассказывает о потоках, ядрах и вытесняющей многозадачности. Почему лучше переиспользовать потоки и другие дорогостоящие ресурсы? И что такое мультиплексирование? Смотрите в видео.
Consistent hashing, Rendezvous hashing | Вопросы собеседований
Просмотров 2 тыс.Год назад
Consistent hashing, Rendezvous hashing | Вопросы собеседований | Backend Developer Interview 3 ССЫЛКА НА КУРС: it-es-course.getcourse.ru/main По промокоду ESCOURSE дополнительная скидка 10% до 11 сентября! Автор курса: Андрей Суховицкий Действующий разработчик ПО, работает над проектированием и разработкой высоконагруженных систем. Последние 4 года создаю и провожу авторские курсы по микросерви...
А как шардировать??? Часть 1 | Вопросы собеседований | Backend Developer Interview #2
Просмотров 2,3 тыс.Год назад
"А как шардировать??" | Вопросы собеседований | Backend Developer Interview #2 ССЫЛКА НА КУРС: it-es-course.getcourse.ru/main По промокоду ESCOURSE дополнительная скидка 10% до 11 сентября! Автор курса: Андрей Суховицкий Действующий разработчик ПО, работает над проектированием и разработкой высоконагруженных систем. Последние 4 года создаю и провожу авторские курсы по микросервисной архитектуре...
Ты используешь CAP-теорему НЕПРАВИЛЬНО! System design интервью
Просмотров 3,7 тыс.Год назад
Ты используешь CAP-теорему НЕПРАВИЛЬНО! System design интервью
Что сказать на собеседовании про обработку топика Kafka
Просмотров 9 тыс.Год назад
Что сказать на собеседовании про обработку топика Kafka
Реализация канала команд (point-to-point) в RabbitMQ
Просмотров 423Год назад
Реализация канала команд (point-to-point) в RabbitMQ
Что сказать на собеседовании про паттерн Saga?
Просмотров 9 тыс.Год назад
Что сказать на собеседовании про паттерн Saga?
RabbitMQ - Порядок сообщений, масштабирование
Просмотров 1,2 тыс.Год назад
RabbitMQ - Порядок сообщений, масштабирование
Разбираем вопросы собеседования на Middle и Senior Developer | Backend Developer Interview #1
Просмотров 12 тыс.2 года назад
Разбираем вопросы собеседования на Middle и Senior Developer | Backend Developer Interview #1
Транзакция по переводу денег. Two phase commit
Просмотров 2 тыс.2 года назад
Транзакция по переводу денег. Two phase commit
Синхронность и асинхронность. Synchronous VS Asynchronous
Просмотров 2,1 тыс.2 года назад
Синхронность и асинхронность. Synchronous VS Asynchronous
Микросервисы и монолиты - что лучше и когда
Просмотров 6592 года назад
Микросервисы и монолиты - что лучше и когда
Надежность, Масштабируемость и Производительность ваших приложений
Просмотров 9732 года назад
Надежность, Масштабируемость и Производительность ваших приложений
6 - Архитектура с брокером сообщений. Kafka. RabbitMQ
Просмотров 1,7 тыс.2 года назад
6 - Архитектура с брокером сообщений. Kafka. RabbitMQ
6 - Надежность. Таймауты, retries, Circuit breaker, Resilience4j, speed control - window/rate limits
Просмотров 8642 года назад
6 - Надежность. Таймауты, retries, Circuit breaker, Resilience4j, speed control - window/rate limits
5 - Синхронность / асинхронность. Процессы и потоки, закон Амдала. Пулы потоков, Executor service
Просмотров 1,2 тыс.2 года назад
5 - Синхронность / асинхронность. Процессы и потоки, закон Амдала. Пулы потоков, Executor service
4 - API compatibility, Protobuf. Document-oriented, relational and graph data models.
Просмотров 5322 года назад
4 - API compatibility, Protobuf. Document-oriented, relational and graph data models.
3 - TCP, HTTP, REST - resource, URI, representation
Просмотров 9462 года назад
3 - TCP, HTTP, REST - resource, URI, representation
2 - Практическое занятие Event storming
Просмотров 1,4 тыс.2 года назад
2 - Практическое занятие Event storming
1 - Архитектура, микросервисы и монолиты
Просмотров 2,9 тыс.2 года назад
1 - Архитектура, микросервисы и монолиты
ИТМО - Проектирование ПО - Лекция 18 - Messaging - RabbitMQ, Kafka
Просмотров 8992 года назад
ИТМО - Проектирование ПО - Лекция 18 - Messaging - RabbitMQ, Kafka
ИТМО - Проект. ПО - Лекция 17 - Асинхронные сообщения. Брокер сообщений. Async messaging, brokers.
Просмотров 7172 года назад
ИТМО - Проект. ПО - Лекция 17 - Асинхронные сообщения. Брокер сообщений. Async messaging, brokers.
ИТМО - Проект. ПО - Лекция 15 - API. Изменения API, совместимость. Форматы данных. Protocol buffers.
Просмотров 4642 года назад
ИТМО - Проект. ПО - Лекция 15 - API. Изменения API, совместимость. Форматы данных. Protocol buffers.
ИТМО - Проект. ПО - Лекция 14 - Prometheus. Counter, Gauge, Summary, Histogram. Quantiles. Grafana
Просмотров 3,8 тыс.2 года назад
ИТМО - Проект. ПО - Лекция 14 - Prometheus. Counter, Gauge, Summary, Histogram. Quantiles. Grafana
ИТМО - Проект. ПО - Лекция 13 - Prometheus. Counter, Gauge. Запросы и агрегации. Grafana
Просмотров 1,9 тыс.2 года назад
ИТМО - Проект. ПО - Лекция 13 - Prometheus. Counter, Gauge. Запросы и агрегации. Grafana
ИТМО - Проектирование ПО - Лекция 12 - Надежное синхронное взаимодействие
Просмотров 8823 года назад
ИТМО - Проектирование ПО - Лекция 12 - Надежное синхронное взаимодействие
ИТМО - Проектирование ПО - Лекция 11 - Межпроцессное взаимодействие. Thread pool, ExecutorService
Просмотров 6783 года назад
ИТМО - Проектирование ПО - Лекция 11 - Межпроцессное взаимодействие. Thread pool, ExecutorService
Видео прям топовые!) Спасибо Андрею
Больше постов о нагрузке с иллюстрациями на моем канале - t.me/andrey_threads
Имхо, ненадёжно не делать компенсации у последней транзакции, т.к. когда-нибудь появился следующая n+1 транзакция и про n-ую забудут и не реализуют компенсацию
С возвращением!🎉
Очень круто рассказано
спасибо!
полезная информация, ждем больше видео и больше постов!
Спасибо, буду стараться!
если при синхронной репликации отдавать пользователю ОК только когда записали во все follower, тогда линеаризуемость вполне будет: следующее чтение, согласно линеаризации, должно происходить после успешной операции предыдущего, то есть уже к моменту завершения репликации
Просто огромнейшее спасибо за подобный материал в открытом доступе. Не поступил в итмо, но могу посмотреть лекции, кайф!)))) Еще вопрос - на каком курсе изучают эти лекции?
как по мне просто отлично, Юрка наверно половину не понял 😁 т.к. таких развёрнутых ответов на собесах не встретишь
Про снапшот конечно смешно, когда человек называет снимок всей таблы хорошим решением... Но он хотя бы говорит свою шизу, а что у остальных в головах - вообще не понятно
Как же тихо...
41:09 а разве фичу с весами нельзя добавить в Rendezvous hasing? например добавив суррогатный ключ? (обозначу его через 's') hash( K + "s1"+ '1') hash( K + "s1"+ '2') hash( K + "s1"+ '3') hash( K + "s1"+ '4') <- добавляем "сильную ноду 4" hash( K + "s2"+ '4') <- добавляем "сильную ноду 4"
в конце подвели итог - всё это знать прикольно, но в общем и не нужно xD
Речь шла про dead letter queue в одном месте, видимо. К сожалению, Kafka не поддерживает DLQ в отличие от AWS SQS, например. Но как отметили это хорошо работает при условии идемпотентности и ассоциативности, иначе начинается пляска с синхронизацией очередей.
О, Нифёдыч в it вкатился
За такое дизлайк по факту видео самореклама а информации по теме нет.
Топ!
Когда-то разбирался с этим вопросом, понял эту теорему совсем по-другому: 1) partitioning tolerance - это свойство переживать разрыв сети. Разрыв сети - это когда все узлы работают, но между ними возник split brain, который потом полечился. Да, сеть имеет свойство пропадать, поэтому распрелеленные системы не способные пережить разрыв сети нам не интересны. 2) availability - это способность сохранять работоспособность пока работает хотя бы один узел 3) consistency - это когда система возвращает одинаковый ответ на одинаковый запрос, независимо от узла, к которому обращаются. И раз P нужна всегда, то речь может идти о CP системах и AP системах. CP - это когда запись в одну ноду сразу дублируется во все ноды. Она не может быть available, т. к. если часть нод временно не ответит, то система должна прекратить обслуживать запросы (иначе с неответившей ноды могут прилететь неконсистентные данные) AP - это большая часть nosql субд: система будет отвечать "до последнего", но иногда данные могут быть устаревшими т. к. мы не синхронизируемся в момент записи и допускаем чтение когда часть нод лежит. На самом деле CA систему тоже можно представить: это зеркало их 2-х реляционных субд с двумя мастерами и синхронной репликацией. Все будет консистентно, умершая нода потом сможет накатить лог транзакций с живой и восстановиться, но вот split brain (когда ноды потеряли связь и продолжили работать не зная что вторая нода жива и тоже что-то пишет) эта схема не переживет.
Split brain это как раз таки не описание состояния partitioning tolerance, а описание partitioning tolerance и точно неконсистентных систем. Если кластер, скажем, поделился на две части и при этом смог выбрать лидера с обеих сторон и решить, что теперь он будет работать, как два независимых кластера. Availability - это не просто способность сохранять работоспособность пока работает хотя бы один узел, а обслуживать любые запросы на любой из нод кластера. Суть в том, что большинство статей описывают вообще не CAP теорему, а просто "в какую стороную больше склоняется система", быть доступной или быть консистентной в присутствии разрыва сети. Я прикладывал в описании конкретные работы, где вводилось понятие CAP теоремы, это академические работы, можете ознакомиться с ними, как с первоисточником.
Очень познавательно, спасибо!
Очень понятное объяснение, спасибо)
СОМНИТЕЛЬНО, но окэй
Отличное видео! Сейчас разбираюсь с метриками, очень такого не хватало.
Крутая лекция, спасибо! Из слайда, объясняющего работу WAL, осталось не очень понятно, что произойдёт, если отключится питание в момент, когда мы записали файл-сегмент с отсортированными данными из in-memory structure, но не успели подать команду discard offer flush. Получается WAL у нас останется заполненным после восстановления? Не произойдёт ли дублирования сегмента?
Отличный разбор. Спасибо! А разве репликация и наличие нескольких нод не подразумевает наличия сети, и соответственно, не допускает ее разделения (сегментации)?
спасибо) Да, конечно, любая система, где между узлами пролегает сеть является распределенной и, конечно, предполагает ситуация разрыва сети.
100 партиций на топик это конечно сильно и универсально, такое количество вероятно в любом кластере сделает меньший перформанс - каждая партиция файловый дескриптор, каждая партиция это усложнение этапа ребаланса, увеличивать партиции - норма, и да кафка ничего не сделает, обычно просто предупреждают и потом убеждаются что консюмер группы дошли до конца, а кто нет - его проблемы. К универсальному запасу в 100 и возможному экспоненциальному приросту нагрузки заранее невозможно подготовиться, в теории и со 100 партиций может придется апскейлится, если так страшно - то вы можете перелить данные в новый топик с новым количеством партиций.
Забыл поместить ссылку на курс :) Вот она - it-es-course.getcourse.ru/main. Мои мини-курсы можно увидеть на степике stepik.org/a/202085 и udemy - www.udemy.com/user/andrei-sukhovitskii/
Где комментарий
34:17 "Разобраться с Кибаной - это, наверное, минут 20 составит". Такой смешной лектор. Такие шутки отпускает - ухохочешься. Пусть идет за 20 минут KQL изучит. Приду - проверю.
Это студенты первого-второго курсов?
Кто писал кафку, с вики: Kafka was originally developed at LinkedIn, and was subsequently open sourced in early 2011. Jay Kreps, Neha Narkhede and Jun Rao helped co-create Kafka.
Огонь. Пошел смотреть новую версию по метрикам.
Вы забыли упомянуть, что: 1 нужно решать вопрос консистентности, пока финалтная маленькая транзакция не закомичена, система находится в неконсистентном состоянии, и нужно уметь с зтим жить. 2 процесс отката маленьких транзакций иакде может обломаться, это собственно коррелирует с первыми вопросом. И с жтим также нужно уметь жить.
Распространенные бизнес ошибки - ошибка десериализации или валидации. распространеные технические ошибки - ошибки ввода/вывода при коммуникации с низлежащими сервисами, недоступность низлежащих сервисов, сетевые ошибки типа 502/503/504
Размазали видео почти на час, много воды (верю, что это препод из универа). Лучше идти по сценарию интервью и придерживаться ему.
Андрей, можете сказать пожалуйста название и модель вашего планшета?)
Да, конечно. Это Huion GT-133. Не могу его сильно рекомендовать, основная претензия в том, что у него довольно странный адаптер, который после нескольких месяцев использования разболтался, что приводит к отключению питания планшета переодически. В остальном неплох.
блиии максимально просто максимально кратко но максимально непонятно :) может на курсе расскажете?
:) расскажу, конечно!
Спасибо за лекцию
Спасибо за лекцию
Спасибо за лекцию
Спасибо за лекцию
29:36 В графане есть версионирование бордов! Вкладка Versions в настройках самой борды
Спасибо за лекцию
Спасибо за лекцию
Спасибо за лекцию
Спасибо за лекцию
Спасибо за лекцию
Спасибо за лекцию
Спасибо за лекцию
Спасибо за лекцию
Спасибо за лекцию