Андрей Суховицкий
Андрей Суховицкий
  • Видео 103
  • Просмотров 136 738
Буферизация запросов и когда она эффективна. 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 - Архитектура, микросервисы и монолиты
2 - Domain driven design
Просмотров 1,1 тыс.2 года назад
2 - Domain driven design
ИТМО - Проектирование ПО - Лекция 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

Комментарии

  • @МаксМакс-ч8к
    @МаксМакс-ч8к 29 дней назад

    Видео прям топовые!) Спасибо Андрею

  • @sukhoa
    @sukhoa Месяц назад

    Больше постов о нагрузке с иллюстрациями на моем канале - t.me/andrey_threads

  • @jagobingIT
    @jagobingIT Месяц назад

    Имхо, ненадёжно не делать компенсации у последней транзакции, т.к. когда-нибудь появился следующая n+1 транзакция и про n-ую забудут и не реализуют компенсацию

  • @mamonov01
    @mamonov01 Месяц назад

    С возвращением!🎉

  • @adwawdwad2499
    @adwawdwad2499 Месяц назад

    Очень круто рассказано

    • @sukhoa
      @sukhoa Месяц назад

      спасибо!

  • @MikitaIsakau
    @MikitaIsakau Месяц назад

    полезная информация, ждем больше видео и больше постов!

    • @sukhoa
      @sukhoa Месяц назад

      Спасибо, буду стараться!

  • @alexborodin366
    @alexborodin366 Месяц назад

    если при синхронной репликации отдавать пользователю ОК только когда записали во все follower, тогда линеаризуемость вполне будет: следующее чтение, согласно линеаризации, должно происходить после успешной операции предыдущего, то есть уже к моменту завершения репликации

  • @timur.piftaev
    @timur.piftaev 2 месяца назад

    Просто огромнейшее спасибо за подобный материал в открытом доступе. Не поступил в итмо, но могу посмотреть лекции, кайф!)))) Еще вопрос - на каком курсе изучают эти лекции?

  • @bubbletubbe
    @bubbletubbe 2 месяца назад

    как по мне просто отлично, Юрка наверно половину не понял 😁 т.к. таких развёрнутых ответов на собесах не встретишь

  • @winter-lb7id
    @winter-lb7id 3 месяца назад

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

  • @ankofl
    @ankofl 4 месяца назад

    Как же тихо...

  • @АндрейСиманов-л3я
    @АндрейСиманов-л3я 4 месяца назад

    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"

  • @mertviy_games
    @mertviy_games 4 месяца назад

    в конце подвели итог - всё это знать прикольно, но в общем и не нужно xD

  • @dragvs
    @dragvs 5 месяцев назад

    Речь шла про dead letter queue в одном месте, видимо. К сожалению, Kafka не поддерживает DLQ в отличие от AWS SQS, например. Но как отметили это хорошо работает при условии идемпотентности и ассоциативности, иначе начинается пляска с синхронизацией очередей.

  • @fischer960
    @fischer960 5 месяцев назад

    О, Нифёдыч в it вкатился

  • @whazapbaz
    @whazapbaz 6 месяцев назад

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

  • @SmadyarovBerik
    @SmadyarovBerik 7 месяцев назад

    Топ!

  • @tsc472
    @tsc472 7 месяцев назад

    Когда-то разбирался с этим вопросом, понял эту теорему совсем по-другому: 1) partitioning tolerance - это свойство переживать разрыв сети. Разрыв сети - это когда все узлы работают, но между ними возник split brain, который потом полечился. Да, сеть имеет свойство пропадать, поэтому распрелеленные системы не способные пережить разрыв сети нам не интересны. 2) availability - это способность сохранять работоспособность пока работает хотя бы один узел 3) consistency - это когда система возвращает одинаковый ответ на одинаковый запрос, независимо от узла, к которому обращаются. И раз P нужна всегда, то речь может идти о CP системах и AP системах. CP - это когда запись в одну ноду сразу дублируется во все ноды. Она не может быть available, т. к. если часть нод временно не ответит, то система должна прекратить обслуживать запросы (иначе с неответившей ноды могут прилететь неконсистентные данные) AP - это большая часть nosql субд: система будет отвечать "до последнего", но иногда данные могут быть устаревшими т. к. мы не синхронизируемся в момент записи и допускаем чтение когда часть нод лежит. На самом деле CA систему тоже можно представить: это зеркало их 2-х реляционных субд с двумя мастерами и синхронной репликацией. Все будет консистентно, умершая нода потом сможет накатить лог транзакций с живой и восстановиться, но вот split brain (когда ноды потеряли связь и продолжили работать не зная что вторая нода жива и тоже что-то пишет) эта схема не переживет.

    • @sukhoa
      @sukhoa 7 месяцев назад

      Split brain это как раз таки не описание состояния partitioning tolerance, а описание partitioning tolerance и точно неконсистентных систем. Если кластер, скажем, поделился на две части и при этом смог выбрать лидера с обеих сторон и решить, что теперь он будет работать, как два независимых кластера. Availability - это не просто способность сохранять работоспособность пока работает хотя бы один узел, а обслуживать любые запросы на любой из нод кластера. Суть в том, что большинство статей описывают вообще не CAP теорему, а просто "в какую стороную больше склоняется система", быть доступной или быть консистентной в присутствии разрыва сети. Я прикладывал в описании конкретные работы, где вводилось понятие CAP теоремы, это академические работы, можете ознакомиться с ними, как с первоисточником.

  • @ДмитрийПечников-у7ш
    @ДмитрийПечников-у7ш 7 месяцев назад

    Очень познавательно, спасибо!

  • @ДмитрийПечников-у7ш
    @ДмитрийПечников-у7ш 8 месяцев назад

    Очень понятное объяснение, спасибо)

  • @Denis-sds
    @Denis-sds 8 месяцев назад

    СОМНИТЕЛЬНО, но окэй

  • @levaryazan
    @levaryazan 8 месяцев назад

    Отличное видео! Сейчас разбираюсь с метриками, очень такого не хватало.

  • @Квадрососисон-ш9у
    @Квадрососисон-ш9у 8 месяцев назад

    Крутая лекция, спасибо! Из слайда, объясняющего работу WAL, осталось не очень понятно, что произойдёт, если отключится питание в момент, когда мы записали файл-сегмент с отсортированными данными из in-memory structure, но не успели подать команду discard offer flush. Получается WAL у нас останется заполненным после восстановления? Не произойдёт ли дублирования сегмента?

  • @YuriySamorodov
    @YuriySamorodov 8 месяцев назад

    Отличный разбор. Спасибо! А разве репликация и наличие нескольких нод не подразумевает наличия сети, и соответственно, не допускает ее разделения (сегментации)?

    • @sukhoa
      @sukhoa 7 месяцев назад

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

  • @HideDJeker
    @HideDJeker 8 месяцев назад

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

  • @sukhoa
    @sukhoa 8 месяцев назад

    Забыл поместить ссылку на курс :) Вот она - it-es-course.getcourse.ru/main. Мои мини-курсы можно увидеть на степике stepik.org/a/202085 и udemy - www.udemy.com/user/andrei-sukhovitskii/

  • @timurbaburin8668
    @timurbaburin8668 9 месяцев назад

    Где комментарий

  • @ЛеонидКоролев-л5щ
    @ЛеонидКоролев-л5щ 9 месяцев назад

    34:17 "Разобраться с Кибаной - это, наверное, минут 20 составит". Такой смешной лектор. Такие шутки отпускает - ухохочешься. Пусть идет за 20 минут KQL изучит. Приду - проверю.

  • @ЛеонидКоролев-л5щ
    @ЛеонидКоролев-л5щ 9 месяцев назад

    Это студенты первого-второго курсов?

  • @cbrnt4157
    @cbrnt4157 10 месяцев назад

    Кто писал кафку, с вики: 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.

  • @АлексейБондаренко-т8т
    @АлексейБондаренко-т8т 10 месяцев назад

    Огонь. Пошел смотреть новую версию по метрикам.

  • @alext6083
    @alext6083 Год назад

    Вы забыли упомянуть, что: 1 нужно решать вопрос консистентности, пока финалтная маленькая транзакция не закомичена, система находится в неконсистентном состоянии, и нужно уметь с зтим жить. 2 процесс отката маленьких транзакций иакде может обломаться, это собственно коррелирует с первыми вопросом. И с жтим также нужно уметь жить.

  • @alexshavlovsky7922
    @alexshavlovsky7922 Год назад

    Распространенные бизнес ошибки - ошибка десериализации или валидации. распространеные технические ошибки - ошибки ввода/вывода при коммуникации с низлежащими сервисами, недоступность низлежащих сервисов, сетевые ошибки типа 502/503/504

  • @МихаилА-у3л
    @МихаилА-у3л Год назад

    Размазали видео почти на час, много воды (верю, что это препод из универа). Лучше идти по сценарию интервью и придерживаться ему.

  • @mamonov01
    @mamonov01 Год назад

    Андрей, можете сказать пожалуйста название и модель вашего планшета?)

    • @sukhoa
      @sukhoa Год назад

      Да, конечно. Это Huion GT-133. Не могу его сильно рекомендовать, основная претензия в том, что у него довольно странный адаптер, который после нескольких месяцев использования разболтался, что приводит к отключению питания планшета переодически. В остальном неплох.

  • @jukovb111
    @jukovb111 Год назад

    блиии максимально просто максимально кратко но максимально непонятно :) может на курсе расскажете?

    • @sukhoa
      @sukhoa Год назад

      :) расскажу, конечно!

  • @applemodus
    @applemodus Год назад

    Спасибо за лекцию

  • @applemodus
    @applemodus Год назад

    Спасибо за лекцию

  • @applemodus
    @applemodus Год назад

    Спасибо за лекцию

  • @applemodus
    @applemodus Год назад

    Спасибо за лекцию

  • @1apaladin
    @1apaladin Год назад

    29:36 В графане есть версионирование бордов! Вкладка Versions в настройках самой борды

  • @applemodus
    @applemodus Год назад

    Спасибо за лекцию

  • @applemodus
    @applemodus Год назад

    Спасибо за лекцию

  • @applemodus
    @applemodus Год назад

    Спасибо за лекцию

  • @applemodus
    @applemodus Год назад

    Спасибо за лекцию

  • @applemodus
    @applemodus Год назад

    Спасибо за лекцию

  • @applemodus
    @applemodus Год назад

    Спасибо за лекцию

  • @applemodus
    @applemodus Год назад

    Спасибо за лекцию

  • @applemodus
    @applemodus Год назад

    Спасибо за лекцию

  • @applemodus
    @applemodus Год назад

    Спасибо за лекцию