Асинхронность: не всегда панацея для производительности

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

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

Более того, эксперимент с высоконагруженным сервисом, изначально написанным в неблокирующем стиле, показал, что переписывание его в блокирующий с пулом потоков, привело к увеличению производительности на 15%. Это говорит о том, что Spring и неблокирующий Tomcat могут создавать дополнительную нагрузку, особенно при обработке десятков тысяч запросов в секунду.

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


Новое на сайте

19167Севернокорейская хакерская группировка Lazarus маскирует вредоносный код под тестовые... 19166Государственные хакеры используют Google Gemini для кибершпионажа и клонирования моделей... 19165Можно ли построить мировую сверхдержаву на чашках чая и фунтах сахара? 19164Уязвимые обучающие приложения открывают доступ к облакам Fortune 500 для криптомайнинга 19163Почему ботнет SSHStalker успешно атакует Linux уязвимостями десятилетней давности? 19162Microsoft устранила шесть уязвимостей нулевого дня и анонсировала радикальные изменения в... 19161Эскалация цифровой угрозы: как IT-специалисты КНДР используют реальные личности для... 19160Скрытые потребности клиентов и преимущество наблюдения над опросами 19159Академическое фиаско Дороти Паркер в Лос-Анджелесе 19158Китайский шпионский фреймворк DKnife захватывает роутеры с 2019 года 19157Каким образом корейские детские хоры 1950-х годов превратили геополитику в музыку и... 19156Научная революция цвета в женской моде викторианской эпохи 19155Как новый сканер Microsoft обнаруживает «спящих агентов» в открытых моделях ИИ? 19154Как новая кампания DEADVAX использует файлы VHD для скрытой доставки трояна AsyncRAT? 19153Как новые китайские киберкампании взламывают госструктуры Юго-Восточной Азии?
Ссылка